总体架构目录:ASP.NET Core分布式项目实战-目录html
k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录node
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找到连到本身的容器,把报文发送过去。网络
根据以前文章中的环境规划,flanneld环境目前是部署在node节点上。(连个node服务器都按此步骤操做便可)架构
须要两个文件,一个是flanneld 二进制包、一个是配置文件生成命令文件(此文件须要入QQ群找群主获取,QQ群号在下面)asp.net
cp flanneld mk-docker-opts.sh /opt/kubernetes/bin/分布式
命令:工具
/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
systemctl start flanneld
systemctl enable flanneld
systemctl daemon-reload
systemctl restart docker
asp.net Core 交流群:787464275 欢迎加群交流
若是您认为这篇文章还不错或者有所收获,您能够点击右下角的【推荐】按钮精神支持,由于这种支持是我继续写做,分享的最大动力!
微信公众号:欢迎关注 QQ技术交流群: 欢迎加群