Kubenetes里pod和service绑定的实现方式

发布时间:2020-08-08 06:13:49 作者:i042416
来源:ITPUB博客 阅读:208

我之前的文章  如何在Kubernetes里创建一个Nginx service 介绍了如何创建一个Kubernetes pod和service,使用的方法是命令kubectl run。

本文介绍另一种方式,通过这种方式来学习Kubernetes里pod和对应的service是如何绑定的。

首先使用下面的命令行创建一个名称为jerry-nginx-1982的deployment:

kubectl create deployment jerry-nginx-1982 --image=nginx

Kubenetes里pod和service绑定的实现方式

然后使用命令行kubectl get deployment 得到创建好的deployment:

然后创建一个同名的service,类型为nodeport。

kubectl create service nodeport jerry-nginx-1982 --tcp 80:80

创建完成后,使用命令行kubectl get svc得到名称为jerry-nginx-1982对外暴露的端口号:31954:

Kubenetes里pod和service绑定的实现方式

然后就能通过这个端口号访问nginx server了:

Kubenetes里pod和service绑定的实现方式

那么这两个同名的pod和service是如何关联的呢?

首先打开kubernetes dashboard,找到之前创建的pod:

Kubenetes里pod和service绑定的实现方式

其明细为:jerry-nginx-1982-67cb658cb8-9hl99

Kubenetes里pod和service绑定的实现方式

再打开同名service:

Kubenetes里pod和service绑定的实现方式

再打开这个service里的pod,发现就是我们前面找到的jerry-nginx-1982-67cb658cb8-9hl99,说明pod和service是通过名称关联的。

Kubenetes里pod和service绑定的实现方式

我们可以做一个negative测试,直接创建一个名为test的service,但不给它预先创建名为test的pod:

kubectl create service nodeport test --tcp 80:80

service创建成功后,打开这个service,发现里面没有分配任何pod:

Kubenetes里pod和service绑定的实现方式

这个结果和我们预测的一致。

要获取更多Jerry的原创文章,请关注公众号"汪子熙":



推荐阅读:
  1. 【K8S排错】在集群的POD内不能访问clusterIP和service
  2. Kubernetes中,通过Service访问Pod快速入门

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

kubenetes 实现 pod

上一篇:LATCH:ROW CACHE OBJECTS故障处理

下一篇:浅析Java语言中的内部类

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》