calico网络原理,容器网络calico基本原理和模拟
calico网络原理,容器网络calico基本原理和模拟Calico 为容器和 vm 等提供一个安全的网路互联方法,我们把 VM、Container、白盒等实例统称为 workloads,通过给 workload 分配一个扁平的三层路由可达 IP 地址实现转发,是一种纯三层转发的方案,workload 之间不使用隧道或 NAT 技术,这种方式提供更好的网络性能,提高易维护和可交互性。同时也支持 IPIP 隧道和与 Flannel 集成能力。Calico 提供动态实施的网络安全策略,可使用简单的安全模型语言实现细粒度的安全控制。总结如下:Calico provides secure network connectivity for Containers and virtual machine workloads.Calico creates and manages a flat layer 3 network assigning each wo
摘要
在容器网络跨 Host 互联方案中,除了 Flannel 的隧道实现方案,还有一种比较主流的纯三层路由的方案 Calico ,与 Flannel 不同的是 Calico 不使用隧道或 NAT 来实现转发,而是巧妙的把所有二三层流量转换成三层流量,并通过 host 上路由配置完成跨 Host 转发,本文对 Calico 的方案进行基本原理分析和模拟验证。
简介
Calico 官方定义如下:
Calico provides secure network connectivity for Containers and virtual machine workloads.
Calico creates and manages a flat layer 3 network assigning each workload a fully routable IP address. Workloads can communicate without IP encapsulation or network address translation for bare metal performance easier troubleshooting and better interoperability. In environments that require an overlay Calico uses IP-in-IP tunneling or can work with other overlay networking such as flannel.
Calico also provides dynamic enforcement of network security rules. Using Calico’s simple policy language you can achieve fine-grained control over communications between containers virtual machine workloads and bare metal host endpoints.
总结如下:
Calico 为容器和 vm 等提供一个安全的网路互联方法,我们把 VM、Container、白盒等实例统称为 workloads,通过给 workload 分配一个扁平的三层路由可达 IP 地址实现转发,是一种纯三层转发的方案,workload 之间不使用隧道或 NAT 技术,这种方式提供更好的网络性能,提高易维护和可交互性。同时也支持 IPIP 隧道和与 Flannel 集成能力。Calico 提供动态实施的网络安全策略,可使用简单的安全模型语言实现细粒度的安全控制。
相对 Overlay,为什么用 Calico?
Calico 有一篇官方 博文 说明,总结如下:
- Felix:运行在每一台 Host 的 agent 进程,主要负责网络接口管理和监听、路由、ARP 管理、ACL 管理和同步、状态上报等
- Orchestrator Plugin:编排插件,并不是独立运行的某些进程,而是设计与 k8s、OpenStack 等平台集成的插件,如 Neutron’s ML2 plugin 用于用户使用 Neutron API 来管理 Calico,本质是要解决模型和 API 间的兼容性问题。
- Etcd:Calico 模型的存储引擎。
- BGP Client(BIRD):Calico 为每一台 Host 部署一个 BGP Client,使用 BIRD 实现,BIRD 是一个单独的持续发展的项目,实现了众多动态路由协议比如 BGP、OSPF、RIP 等。在 Calico 的角色是监听 Host 上由 Felix 注入的路由信息,然后通过 BGP 协议广播告诉剩余 Host 节点,从而实现网络互通。
- BGP Route Reflector(BIRD):在大型网络规模中,如果仅仅使用 BGP client 形成 mesh 全网互联的方案就会导致规模限制,因为所有节点之间俩俩互联,需要 N^2 个连接,为了解决这个规模问题,可以采用 BGP 的 Router Reflector 的方法,使所有 BGP Client 仅与特定 RR 节点互联并做路由同步,从而大大减少连接数。
模拟组网
组网如下:
- guest 配置 169.254.1.1 的默认路由
- host 上配置 10.20.2.0/24 和 10.20.1.3/32 路由
- 开启 arp proxy 和 ip_forward 能力
网络连通性测试:
# HOST0 [root@i-7dlclo08 ~]# ip netns exec ns0 ping 10.20.2.2 PING 10.20.2.2 (10.20.2.2) 56(84) bytes of data. bytes from 10.20.2.2: icmp_seq=1 ttl=62 time=0.774 ms bytes from 10.20.2.2: icmp_seq=2 ttl=62 time=0.332 ms
10.20.1.2 与跨 Host 跨子网 10.20.2.2 互通成功
# HOST0 [root@i-7dlclo08 ~]# ip netns exec ns0 ping 10.20.1.3 PING 10.20.1.3 (10.20.1.3) 56(84) bytes of data. bytes from 10.20.1.3: icmp_seq=1 ttl=62 time=957 ms bytes from 10.20.1.3: icmp_seq=2 ttl=62 time=0.432 ms bytes from 10.20.1.3: icmp_seq=3 ttl=62 time=0.563 ms
10.20.1.2 与跨 Host 同子网 10.20.1.3 互通成功
[root@i-7dlclo08 ~]# ip netns exec ns0 ping 192.168.100.3 PING 192.168.100.3 (192.168.100.3) 56(84) bytes of data. bytes from 192.168.100.3: icmp_seq=1 ttl=63 time=1.00 ms bytes from 192.168.100.3: icmp_seq=2 ttl=63 time=0.695 ms
在未做安全策略下,10.20.1.2 与 Host 192.168.100.3 互通成功
转发过程:
- guest0 本地所有数据包都转发到一个虚假的地址 169.254.1.1,发送 arp Req。
- Host0 的 veth 端收到 ARP Req 时通过开启网卡的 proxy arp 代理功能直接把自己的 MAC 地址返回给 guest0
- guest0 发送目的地址为 guest1 的 IP 数据包
- 因为使用了 169.254.1.1 这样的地址,Host 判断为三层路由转发,查询本地路由 10.20.2.0/24 via 192.168.0.3 dev eth0 发送给对端 host1,如果配置 BGP,这里会看到 proto 协议为 BIRD
- 在发送之前匹配本地的 iptables 规则进行安全策略控制,这里略
- 当 host1 收到 10.20.2.2 的数据包时查找本地路由表匹配 10.20.2.2/32 dev veth0 scope link 转发到对应的 veth0 端从而到达 guest1
- 回程类似,略
整体转发流程简单清晰。因此可以看到,Calico 需要给所有 guest 配置一条特别的路由并利用 veth 的 proxy arp 的能力让 guest 出来的所有转发都变成三层路由转发,再利用 host 的路由表进行转发,这种方式不仅仅实现了同 host 的二三层转发,也能实现跨 host 的转发。
遗留问题
- 租户隔离问题
- Calico 的三层方案是直接在 host 上进行路由寻址,那么对于多租户如果使用同一个 CIDR 网络就面临着地址冲突的问题。
- 路由规模问题
- 通过路由规则可以看出,路由规模和 guest 分布有关,如果 guest 离散分布在 host 集群中,势必会产生较多的路由项。
- iptables 规则规模问题
- 1台 Host 上可能虚拟化十几或几十个容器实例,过多的 iptables 规则造成复杂性和不可调试性,同时也存在性能损耗。
- 跨子网时的网关路由问题
- 当对端网络不为二层可达时,需要通过三层路由机时,需要网关支持自定义路由配置,即 guest 的目的地址为本网段的网关地址,再由网关进行跨三层转发。
总结
- Calico 通过巧妙的引导 workload 所有的流量至一个特殊的网关 169.254.1.1,从而引流到 host 的 calixxx 网络设备上,形成了二三层流量全部转换 host 的三层流量转发。
- 在 Host 上通过开启 arp proxy 的能力实现 arp 代答,arp 广播被抑制在 host 里,arp 记录变成“无效记录”,抑制了广播风暴和不会有 arp 表膨胀的问题。
- 使用 iptables 在 host 做 policy 实现的复杂的安全模型,安全策略应用在每一台虚拟路由器上,最终形成了一个分布式的安全系统。