K8S中如何跨namespace 访问服务?为什么ping不通ClusterIP?

 

1、K8S中如何跨namespace 访问服务?

2、在Pod中为什么ping不通ClusterIP?

 

简述

        Rancher2.0中的一个用户,在K8S环境中,创建两个namespace,对应用进行分割管理,在一个namespace的pod中,如何访问另一个namespace中的服务?--K8S使用kube-DNS实现服务发现功能的,可以通过DNS名称访问服务名。

        在K8S中,部署一个带ClusterIP的服务,供集群内部网络访问。为什么这个ClusterIP无法ping通?--ClusterIP是IPtable规则,不是绑定在网络接口上的,服务可以访问,但ping不通ClusterIP。

 

演示截图

图1-创建一个包含3台主机、用于演示的集群环境

01-集群环境-3台主机

图2-在命名空间namespace111中,创建一个nginx工作负载,端口映射的运行模式为集群IP

02-在命名空间namespace111中创建一个nginx工作负载-端口映射的运行模式为集群IP

图3-再在另一个命名空间namespace222中,创建一个普通的Ubutnu工作负载

03-再在命名空间namespace222中创建一个工作负载

图4-在服务发现页面中,可以看到,已自动在2个命名空间中创建2条服务记录

04-在服务发现中自动在2个命名空间中创建2条记录

图5-进入2个Pod中,验证不同namespace可以互相访问,集群IP不可以ping,但ClusterIP对应的服务可以访问。

05-不同namespace可以互相访问-集群IP不可以ping但可以访问

图6-网上介绍kubeDNS的文章

06-网上介绍kubeDNS的文章

图7-网上关于ClusterIP相关的帖子及文章

07-网上介绍ClusterIP的文章

 

参考链接:

kube-dns 和服务发现

https://www.cnblogs.com/allcloud/p/7614123.html

kubernetes的service的cluster-ip无法访问

http://dockone.io/question/1086

谈谈kubernets的service组件的Virtual IP

https://ieevee.com/tech/2017/01/20/k8s-service.html

posted @ 2018-06-16 12:08  Docker猫猫  阅读(10388)  评论(0编辑  收藏  举报