kubernetes(k8s)安装BGP模式calico网络支持IPV4和IPV6
kubernetes(k8s)安装BGP模式calico网络支持IPV4和IPV6
BGP是互联网上一个核心的去中心化自治路由协议,它通过维护IP路由表或“前缀”表来实现自治系统AS之间的可达性,属于矢量路由协议。不过,考虑到并非所有的网络都能支持BGP,以及Calico控制平面的设计要求物理网络必须是二层网络,以确保 vRouter间均直接可达,路由不能够将物理设备当作下一跳等原因,为了支持三层网络,Calico还推出了IP-in-IP叠加的模型,它也使用Overlay的方式来传输数据。IPIP的包头非常小,而且也是内置在内核中,因此理论上它的速度要比VxLAN快一点 ,但安全性更差。Calico 3.x的默认配置使用的是IPIP类型的传输方案而非BGP。
Calico的系统架构如图所示:
Calico 主要由 Felix、etcd、BGP client 以及 BGP Route Reflector 组成
Felix,Calico Agent,跑在每台需要运行 Workload 的节点上,主要负责配置路由及 ACLs 等信息来确保 Endpoint 的连通状态;
etcd,分布式键值存储,主要负责网络元数据一致性,确保 Calico 网络状态的准确性;
BGP Client(BIRD), 主要负责把 Felix 写入 Kernel 的路由信息分发到当前 Calico 网络,确保 Workload 间的通信的有效性;
BGP Route Reflector(BIRD),大规模部署时使用,摒弃所有节点互联的 mesh 模式,通过一个或者多个 BGP Route Reflector 来完成集中式的路由分发。
calico/calico-ipam,主要用作 Kubernetes 的 CNI 插件
配置NetworkManager防止干扰calico
1 | [root@k8s-master01 ~]# vim /etc/NetworkManager/conf.d/calico.conf |
下载官方最新calico配置文件
1 | [root@k8s-master01 ~]# curl https://projectcalico.docs.tigera.io/manifests/calico-typha.yaml -o calico.yaml |
修改calico配置得以支持IPV6
1 | [root@k8s-master01 ~]# cp calico.yaml calico-ipv6.yaml |
修改calico配置得以支持IPV4
1 | [root@k8s-master01 ~]# grep "IPV4POOL_CIDR" calico.yaml -A 1 |
查看POD
1 | [root@k8s-master01 ~]# kubectl get pod -A -w |
关于
https://www.oiox.cn/index.php/start-page.html
CSDN、GitHub、知乎、开源中国、思否、掘金、简书、华为云、阿里云、腾讯云、哔哩哔哩、今日头条、新浪微博、个人博客
全网可搜《小陈运维》
文章主要发布于微信公众号:《Linux运维交流社区》