1、背景
公司的项目需要使用容器化部署,为了更好的维护和管理,我将各个项目按照命名空间进行隔离开,但是却发现存在一些问题
不同的系统间需要项目调用,而且是按照服务名进行调用,但是却导致不同名称空间下pod无法解析其他的命令空间下的服务名,需要使用服务名.命名空间才可以解析,如下(存在两个名称空间yshj-ump、和gxjhpt,其中gxjhpt下的pod需要调用yshj-ump下的api服务)

可以看ump-api无法解析,进入gxjhpt下的pod测试域名解析发现确实无法解析,但是可以使用服务名.命名空间便可以解析

手动在pod中的/etc/hosts中添加ump-api的域名解析可以解决,但是这个太现实。
2、解决办法
1. 修改k8s的dns为kubedns
- k8s中负责解析服务名的dns组件有coredns、kubedns等多种,查看命令
kubectl get pod -n kube-system,因此集群上服务互相访问,服务名解析问题首先看服务名是否在同一个命名空间namesapce,服务名是否写正确,其次检查dns组件的版本和工作状态。 - coredns、kubedns二者有个区别,是在解析ExternalName svc时,即访问外部服务有两种组合:kubedns+externalname与coredns+endpoints,这取决于k8s集

本文解决Kubernetes环境中不同命名空间下Pod间的服务名解析问题,通过修改DNS组件、CoreDNS配置及使用hostAliases配置等多种方式,确保跨命名空间的服务调用正常工作。
最低0.47元/天 解锁文章
1306

被折叠的 条评论
为什么被折叠?



