首页
视频
资源
登录
原
Kubernetes Calico BGP RR路由反射器模式
3492
人阅读
2022/11/21 14:02
总访问:
2614140
评论:
0
收藏:
0
手机
分类:
容器编排
![](https://img.tnblog.net/arcimg/hb/cf0187c40cbd4549a3cbad26c140763f.png) >#Kubernetes Calico BGP RR路由反射器模式 [TOC] ## RR路由反射器模式简介 tn2>Calico 维护的网络在默认是(Node-to-Node Mesh)全互联模式,Calico集群中的节点之间都会相互建立连接,用于路由交换。但是随着集群规模的扩大,mesh模式将形成一个巨大服务网格,连接数成倍增加,就会产生性能问题。这时就需要使用 Route Reflector(路由器反射)模式解决这个问题,提升某个路由为RR专门学习新增和相关路由再统一下发。 tn>简单来说:把一个员工(路由)提拔出来当个领导,关于客户端路由学习新的路由时,直接通知领导,领导再统一告知。 ![](https://img.tnblog.net/arcimg/hb/0d22c66db4544ede959e352000f9a3ff.png) ## 安装RR路由反射器模式 >### 设置RR路由反射器节点 tn2>关于Calico安装就不说了。 这里我们将Full Mesh模式直接转换成RR模式。 首先我们查看节点BGP状态。 ```bash calicoctl --allow-version-mismatch node status ``` ![](https://img.tnblog.net/arcimg/hb/19436a800f214fcba2ddcb6108768084.png) tn2>这里我们有三台主机,我们将master主机配置为RR。 首先需要为Master主机打上`calico-route-reflector`标签然后,添加`routeReflectorClusterID`将Master节点设置为集群内的路由反射器(`224.0.0.1`为组播地址)。 ```bash calicoctl --allow-version-mismatch get node <node name> -o yaml --export > node.yaml ``` tn2>在Yaml中添加如下内容。 ```bash metadata: labels: calico-route-reflector: "" spec: bgp: routeReflectorClusterID: 224.0.0.1 ``` ![](https://img.tnblog.net/arcimg/hb/bf568cb35b024eacb118be5d4fc4f1d7.png) tn2>然后更新配置情况。 ```bash calicoctl --allow-version-mismatch apply -f node.yaml ``` ![](https://img.tnblog.net/arcimg/hb/7039bb9d947541b69d4bea66a8e1fa41.png) >### 添加Peer tn2>首先将所有的客户端通过BGPPeer连接到RR上面。 (这里是通过识别是否有`calico-route-reflector`标签来决定的) ```bash calicoctl --allow-version-mismatch apply -f - <<EOF kind: BGPPeer apiVersion: projectcalico.org/v3 metadata: name: peer-to-rrs spec: nodeSelector: "!has(calico-route-reflector)" peerSelector: has(calico-route-reflector) EOF ``` tn2>然后将所有的RR路由反射器连接到一起。 ```bash calicoctl --allow-version-mismatch apply -f - <<EOF kind: BGPPeer apiVersion: projectcalico.org/v3 metadata: name: rrs-to-rrs spec: nodeSelector: has(calico-route-reflector) peerSelector: has(calico-route-reflector) EOF ``` tn2>禁用node-to-node mesh模式中。 ```bash calicoctl --allow-version-mismatch create -f - <<EOF apiVersion: projectcalico.org/v3 kind: BGPConfiguration metadata: name: default spec: nodeToNodeMeshEnabled: false asNumber: 64512 EOF ``` tn2>然后RR配置完成了。 ```bash calicoctl --allow-version-mismatch node status ``` ![](https://img.tnblog.net/arcimg/hb/51cb456995dd4dbd9ca4e2cebcf026b1.png)
欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739
👈{{preArticle.title}}
👉{{nextArticle.title}}
评价
{{titleitem}}
{{titleitem}}
{{item.content}}
{{titleitem}}
{{titleitem}}
{{item.content}}
尘叶心繁
这一世以无限游戏为使命!
博主信息
排名
6
文章
6
粉丝
16
评论
8
文章类别
.net后台框架
168篇
linux
17篇
linux中cve
1篇
windows中cve
0篇
资源分享
10篇
Win32
3篇
前端
28篇
传说中的c
4篇
Xamarin
9篇
docker
15篇
容器编排
101篇
grpc
4篇
Go
15篇
yaml模板
1篇
理论
2篇
更多
Sqlserver
4篇
云产品
39篇
git
3篇
Unity
1篇
考证
2篇
RabbitMq
23篇
Harbor
1篇
Ansible
8篇
Jenkins
17篇
Vue
1篇
Ids4
18篇
istio
1篇
架构
2篇
网络
7篇
windbg
4篇
AI
18篇
threejs
2篇
人物
1篇
嵌入式
2篇
python
13篇
HuggingFace
8篇
pytorch
9篇
opencv
6篇
Halcon
1篇
最新文章
最新评价
{{item.articleTitle}}
{{item.blogName}}
:
{{item.content}}
关于我们
ICP备案 :
渝ICP备18016597号-1
网站信息:
2018-2024
TNBLOG.NET
技术交流:
群号656732739
联系我们:
contact@tnblog.net
欢迎加群
欢迎加群交流技术