kubernetes的服务发现

概述

  本篇介绍kubernetes的服务发现,主要分三部分:k8s 集群内部互相通信、k8s 集群内部访问外部、集群外部访问集群内部。
  解决上述三类通讯就能满足生产中的业务需求。

集群内部

ip访问

  集群内部服务互相访问,可以直接使用对应的 ip 进行访问,但 podip 是不稳定的,经常的发生变化。如下图:
在这里插入图片描述

Service

  Service拥有相对固定的 ip(只要这个Service没有被删除),podA 中连接 Serviceip ,且内部 podB 还可以做至负载均衡。如下图:
在这里插入图片描述

DNS

  使用 Service 还是不够优雅,k8s 又提供了 DNS,能过 Service 名称来定位到 Service ip ,从而访问至 podB

HeadlessService

  当我们需要在 podA 端做负载均衡的时候,DNS 显然是没法满足我们的需要,所以 HeadlessService 出现了,它 podC 的列表返回。如下图:
在这里插入图片描述

集群内 --> 集群外

  当我们需要访问集群外的 mysql 时,一种根据 IP+Port 的方式来直接访问,但此种方式因 mysql 的迁移而变化,导致修改程序,第二种:结合 DNS+Service+Endpoint方式,解决修改程序的缺点。

在这里插入图片描述

集群外–> 集群内

NodePort

  NodePort是在每个物理节点上开个端口,这种可能会导致后期服务增多,端口不够用的情况,而且还多了一层转发,现在的生产中,已经很少用到了。如下图:
在这里插入图片描述

HostPort

  相对于 NodePort ,每个物理节点都会开一个端口,HostPort 只会在 pod 所在物理节点上开一个端口,不会多一次转发。
在这里插入图片描述

Ingress

Ingress官方地址
ingress-nginx deploy
在这里插入图片描述
详细请参考 ingress-nginx离线安装实践

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

流月up

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值