打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
想玩 BGP 路由器么?用 CentOS 做一个

配置BGP对等

Quagga守护进程负责BGP的服务叫bgpd。首先我们来准备它的配置文件。

  1. # cp /usr/share/doc/quagga-XXXXXXX/bgpd.conf.sample /etc/quagga/bgpd.conf

在CentOS6系统中:

  1. # service bgpd start
  2. # chkconfig bgpd on

在CentOS7中:

  1. # systemctl start bgpd
  2. # systemctl enable bgpd

现在,让我们来进入Quagga 的shell。

  1. # vtysh

第一步,我们要确认当前没有已经配置的BGP会话。在一些版本,我们可能会发现一个AS号为7675的BGP会话。由于我们不需要这个会话,所以把它移除。

  1. Router-A# show running-config

  1. ... ... ...
  2. router bgp 7675
  3. bgp router-id 200.200.1.1
  4. ... ... ...

我们将移除一些预先配置好的BGP会话,并建立我们所需的会话取而代之。

  1. Router-A# configure terminal
  2. Router-A(config)# no router bgp 7675
  3. Router-A(config)# router bgp 100
  4. Router-A(config)# no auto-summary
  5. Router-A(config)# no synchronizaiton
  6. Router-A(config-router)# neighbor 100.100.0.2 remote-as 200
  7. Router-A(config-router)# neighbor 100.100.0.2 description "provider B"
  8. Router-A(config-router)# exit
  9. Router-A(config)# exit
  10. Router-A# write

路由器B将用同样的方式来进行配置,以下配置提供作为参考。

  1. Router-B# configure terminal
  2. Router-B(config)# no router bgp 7675
  3. Router-B(config)# router bgp 200
  4. Router-B(config)# no auto-summary
  5. Router-B(config)# no synchronizaiton
  6. Router-B(config-router)# neighbor 100.100.0.1 remote-as 100
  7. Router-B(config-router)# neighbor 100.100.0.1 description "provider A"
  8. Router-B(config-router)# exit
  9. Router-B(config)# exit
  10. Router-B# write

当相关的路由器都被配置好,两台路由器之间的对等将被建立。现在让我们通过运行下面的命令来确认:

  1. Router-A# show ip bgp summary

从输出中,我们可以看到"State/PfxRcd"部分。如果对等关闭,输出将会显示"Idle"或者"Active'。请记住,单词'Active'这个词在路由器中总是不好的意思。它意味着路由器正在积极地寻找邻居、前缀或者路由。当对等是up状态,"State/PfxRcd"下的输出状态将会从特殊邻居接收到前缀号。

在这个例子的输出中,BGP对等只是在AS100和AS200之间呈up状态。因此没有前缀被更改,所以最右边列的数值是0。

配置前缀通告

正如一开始提到,AS 100将以100.100.0.0/22作为通告,在我们的例子中AS 200将同样以200.200.0.0/22作为通告。这些前缀需要被添加到BGP配置如下。

在路由器-A中:

  1. Router-A# configure terminal
  2. Router-A(config)# router bgp 100
  3. Router-A(config)# network 100.100.0.0/22
  4. Router-A(config)# exit
  5. Router-A# write

在路由器-B中:

  1. Router-B# configure terminal
  2. Router-B(config)# router bgp 200
  3. Router-B(config)# network 200.200.0.0/22
  4. Router-B(config)# exit
  5. Router-B# write

在这一点上,两个路由器会根据需要开始通告前缀。

测试前缀通告

首先,让我们来确认前缀的数量是否被改变了。

  1. Router-A# show ip bgp summary

为了查看所接收的更多前缀细节,我们可以使用以下命令,这个命令用于显示邻居100.100.0.2所接收到的前缀总数。

  1. Router-A# show ip bgp neighbors 100.100.0.2 advertised-routes

查看哪一个前缀是我们从邻居接收到的:

  1. Router-A# show ip bgp neighbors 100.100.0.2 routes

我们也可以查看所有的BGP路由器:

  1. Router-A# show ip bgp

以上的命令都可以被用于检查哪个路由器通过BGP在路由器表中被学习到。

  1. Router-A# show ip route

  1. 代码: K - 内核路由, C - 已链接 , S - 静态 , R - 路由信息协议 , O - 开放式最短路径优先协议,
  2.  
  3. I - 中间系统到中间系统的路由选择协议, B - 边界网关协议, > - 选择路由, * - FIB 路由
  4.  
  5. C>* 100.100.0.0/30 is directly connected, eth0
  6. C>* 100.100.1.0/24 is directly connected, eth1
  7. B>* 200.200.0.0/22 [20/0] via 100.100.0.2, eth0, 00:06:45

  1. Router-A# show ip route bgp

  1. B>* 200.200.0.0/22 [20/0] via 100.100.0.2, eth0, 00:08:13

BGP学习到的路由也将会在Linux路由表中出现。

  1. [root@Router-A~]# ip route

  1. 100.100.0.0/30 dev eth0 proto kernel scope link src 100.100.0.1
  2. 100.100.1.0/24 dev eth1 proto kernel scope link src 100.100.1.1
  3. 200.200.0.0/22 via 100.100.0.2 dev eth0 proto zebra

最后,我们将使用ping命令来测试连通。结果将成功ping通。

  1. [root@Router-A~]# ping 200.200.1.1 -c 2

总而言之,本教程将重点放在如何在CentOS系统中运行一个基本的BGP路由器。这个教程让你开始学习BGP的配置,一些更高级的设置例如设置过滤器、BGP属性调整、本地优先级和预先路径准备等,我将会在后续的教程中覆盖这些主题。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
用Linux打造路由器
Zebra基本配置
centos上实现动态路由和NAT功能
如何实现局域网中不同网段互访?企业网必备高级静态路由
热门技术中的应用-容器技术中的网络3-CALICO:为高效说出善意的谎言
协议森林03 IP接力赛 (IP, ARP, RIP和BGP协议)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服