Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之flanneld网络介绍及部署(三)

0、前言


 

总体架构目录:ASP.NET Core分布式项目实战-目录html

k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录node

1、flanneld介绍


 

 flannel是CoreOS提供用于解决Dokcer集群跨主机通信的覆盖网络工具。它的主要思路是:预先留出一个网段,每一个主机使用其中一部分,而后每一个容器被分配不一样的ip;让全部的容器认为你们在同一个直连的网络,底层经过UDP/VxLAN等进行报文的封装和转发。docker

引用官方给出的图片服务器

那么一条网络报文是怎么从一个容器发送到另一个容器的呢?微信

一、容器直接使用目标容器的ip访问,默认经过容器内部的eth0发送出去。
二、报文经过veth pair被发送到vethXXX。
三、vethXXX是直接链接到虚拟交换机docker0的,报文经过虚拟bridge docker0发送出去。
四、查找路由表,外部容器ip的报文都会转发到flannel0虚拟网卡,这是一个P2P的虚拟网卡,而后报文就被转发到监听在另外一端的flanneld。
五、flanneld经过etcd维护了各个节点之间的路由表,把原来的报文UDP封装一层,经过配置的iface发送出去。
六、报文经过主机之间的网络找到目标主机。
七、报文继续往上,到传输层,交给监听在8285端口的flanneld程序处理。
八、数据被解包,而后发送给flannel0虚拟网卡。
九、查找路由表,发现对应容器的报文要交给docker0。
十、docker0找到连到本身的容器,把报文发送过去。网络

 

2、来部署吧


 

根据以前文章中的环境规划,flanneld环境目前是部署在node节点上。(连个node服务器都按此步骤操做便可)架构

须要两个文件,一个是flanneld 二进制包、一个是配置文件生成命令文件(此文件须要入QQ群找群主获取,QQ群号在下面)asp.net

 

一、解压压缩包、而后把解压出来的两个文件复制到 

 cp flanneld mk-docker-opts.sh /opt/kubernetes/bin/分布式

 

二、在master服务节点里面配置网段,供flanneld使用

 命令:工具

/opt/kubernetes/bin/etcdctl --ca-file=ca.pem --cert-file=server.pem --key-file=server-key.pem --endpoints="https://192.168.161.151:2379,https://192.168.161.152:2379,https://192.168.161.153:2379" set /coreos.com/network/config  '{ "Network": "172.17.0.0/16", "Backend": {"Type": "vxlan"}}'

 

 三、执行配置文件里面,能够建立文件

第一:在cfg中建立 flanneld 文件:vi /opt/kubernetes/cfg/flanneld

 FLANNEL_OPTIONS="--etcd-endpoints=https://192.168.161.151:2379,https://192.168.161.152:2379,https://192.168.161.153:2379 -etcd-cafile=/opt/kubernetes/ssl/ca.pem -etcd-certfile=/opt/kubernetes/ssl/server.pem -etcd-keyfile=/opt/kubernetes/ssl/server-key.pem"

 

第二:建立 docker.service => /usr/lib/systemd/system/docker.service

 

第三:建立 /usr/lib/systemd/system/flanneld.service

 

四、启动flanneld 网络,并设置开机启动

systemctl start flanneld
systemctl enable flanneld

五、docker 也须要重启

systemctl daemon-reload

systemctl restart docker

 

六、经过互相ping 能够查看flanneld网络是否设置成功

 命令: ip addr 查看地址,而后在另一台node上ping 172.17.46.0,就能够了

 

 七、下篇文章将要介绍master服务组件部署


 

 

asp.net Core 交流群:787464275 欢迎加群交流
若是您认为这篇文章还不错或者有所收获,您能够点击右下角的【推荐】按钮精神支持,由于这种支持是我继续写做,分享的最大动力!

做者:LouieGuo
声明:原创博客请在转载时保留原文连接或者在文章开头加上本人博客地址,如发现错误,欢迎批评指正。凡是转载于本人的文章,不能设置打赏功能,若有特殊需求请与本人联系!

微信公众号:欢迎关注                                                 QQ技术交流群: 欢迎加群

                

相关文章
相关标签/搜索