开发者

Kubernetes(k8s)代码解读-apiserver之list-watch篇

开发者 https://www.devze.com 2020-01-14 11:41 出处:网络 作者:运维开发整理
apiserver的list-watch代码解读 list-watch,作为k8s系统中统一的异步消息传递方式,对系统的性能、数据一致性起到关键性的作用。今天我想从代码这边探究一下list-watch的实现方式。并看是否能在后面的工作中优化这个过程。 0. list-watch的需求 上图是一个典型的Pod创建过程,在这个过程中,每次当kubectl创建了

Docker官方推荐我们通过端口映射的方式把Docker容器的服务提供给宿主机或者局域网其他容器使用。一般过程是:

1、Docker进程通过监听宿主机的某个端口,将该端口的数据包发送给Docker容器

2、宿主机可以打开防火墙让局域网其他设备通过访问宿主机的端口进而访问docker的端口

但在实际使用中并不是很方便。

以下在win10环境中队DockerDocker容器通过独立IP暴露给局域网的方法进行记录。

Docker的默认启动方式中,会产生一块虚拟网卡,然后容器内自行分配单独的网卡和IP。可以在宿主机上通过ipconfig命令看到这个虚拟网卡。

Kubernetes(k8s)代码解读-apiserver之list-watch篇

打开一个容器,可以看到容器ip地址为自动分配的。

Kubernetes(k8s)代码解读-apiserver之list-watch篇

通过宿主机无法ping通

Kubernetes(k8s)代码解读-apiserver之list-watch篇

通过配置路由表实现ip互通

查看route print

Kubernetes(k8s)代码解读-apiserver之list-watch篇

查看docker 的ip地址

Kubernetes(k8s)代码解读-apiserver之list-watch篇

暴露给宿主机的为10.0.75.1

添加路由

route -p add 172.17.0.0 MASK 255.255.255.0 10.0.75.2

Kubernetes(k8s)代码解读-apiserver之list-watch篇

重新ping容器地址

Kubernetes(k8s)代码解读-apiserver之list-watch篇

现在则可以直接通过ip访问。

由于docker默认采用bridge网络,每次容器启动时自动分配ip,我们可以创建自己的网络bridge1,在创建容器时指定ip,如需独立ip访问则另外增加路由。

route -p add 172.18.12.0 MASK 255.255.255.0 10.0.75.2

如果删除路由:

route delete 172.18.12.0

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号