我们的CentOS设备位于这条专用链路的两端。这两个设备的主机名称分别被设为site-A-RTR和site-B-RTR。下面提供了IP地址的信息信息。
Site-A:192.168.1.0/24
Site-B:172.16.1.0/24
两个Linux设备之间的对等:10.10.10.0/30
Quagga软件包含有几个协同运行的后台程序。我们在本教程中将着重介绍设置下列后台程序。
Zebra:核心后台程序,负责内核接口和静态路由。
Ospfd:IPv4OSPF后台程序。
将Quagga安装到CentOS上
我们首先使用yum来安装Quagga。
#yuminstallquagga
在CentOS7上,SELinux在默认情况下阻止/usr/sbin/zebra写入到其配置目录中。这个SELinux策略干扰了我们所要描述的安装过程,于是我们想禁止该策略。为此,关闭SELinux(不推荐),或者启用zebra_write_config布尔表达式,如下所示。如果你使用CentOS6,可以跳过这一步。
#setsebool-Pzebra_write_config1
要是不进行这种更改,我们在试图从Quagga的命令外壳里面保存Zebra配置时,就会看到下列错误。
Can'topenconfigurationfile/etc/quagga/zebra.conf.OS1Uu5.
(无法打开配置文件/etc/quagga/zebra.conf.OS1Uu5。)
Quagga安装完毕后,我们就配置必要的对等IP地址,并更新OSPF设置。Quagga随带一个名为vtysh的命令行外壳。vtysh里面使用的Quagga命令类似思科或瞻博等各大路由器厂商的那些命令。
第一个阶段:配置Zebra
我们首先创建一个Zebra配置文件,然后启动Zebra后台程序。
#cp/usr/share/doc/quagga-XXXXX/zebra.conf.sample/etc/quagga/zebra.conf
#servicezebrastart
#chkconfigzebraon
启动vtysh命令外壳:
#vtysh
首先,我们为Zebra配置日志文件。为此,输入下列内容,进入vtysh中的全局配置模式:
site-A-RTR#configureterminal
并指定日志文件位置,然后退出该模式:
site-A-RTR(config)#logfile/var/log/quagga/quagga.log
site-A-RTR(config)#exit
永久性保存配置:
site-A-RTR#write
下一步,我们在必要时确定可用接口,然后配置IP地址。
site-A-RTR#showinterface
Interfaceeth0isup,lineprotocoldetectionisdisabled
.....
Interfaceeth1isup,lineprotocoldetectionisdisabled
.....
配置eth0参数:
site-A-RTR#configureterminal
site-A-RTR(config)#interfaceeth0
site-A-RTR(config-if)#ipaddress10.10.10.1/30
site-A-RTR(config-if)#descriptionto-site-B
site-A-RTR(config-if)#noshutdown
继续配置eth1参数:
site-A-RTR(config)#interfaceeth1
site-A-RTR(config-if)#ipaddress192.168.1.1/24
site-A-RTR(config-if)#descriptionto-site-A-LAN
site-A-RTR(config-if)#noshutdown
现在验证配置:
site-A-RTR(config-if)#doshowinterface
Interfaceeth0isup,lineprotocoldetectionisdisabled
.....
inet10.10.10.1/30broadcast10.10.10.3
.....
Interfaceeth1isup,lineprotocoldetectionisdisabled
.....
inet192.168.1.1/24broadcast192.168.1.255
.....
site-A-RTR(config-if)#doshowinterfacedescription
InterfaceStatusProtocolDescription
eth0upunknownto-site-B
eth1upunknownto-site-A-LAN
永久性保存配置:
site-A-RTR(config-if)#dowrite
针对site-B服务器,也重复IP地址配置这个步骤。
要是一切顺利,你应该能够从site-A服务器来ping检测site-B的对等IP10.10.10.2。
请注意:一旦Zebra后台程序已启动,用vtysh的命令行接口进行的任何更改会立即生效。不需要在配置变更后重启Zebra后台程序。
第2个阶段:配置OSPF
我们先创建一个OSPF配置文件,然后启动OSPF后台程序:
#cp/usr/share/doc/quagga-XXXXX/ospfd.conf.sample/etc/quagga/ospfd.conf
#serviceospfdstart
#chkconfigospfdon
现在启动vtysh外壳,继续进行OSPF配置:
#vtysh
进入路由器配置模式:
site-A-RTR#configureterminal
site-A-RTR(config)#routerospf
还可以手动设置router-id:
site-A-RTR(config-router)#router-id10.10.10.1
添加将参与OSPF的网络:
site-A-RTR(config-router)#network10.10.10.0/30area0
site-A-RTR(config-router)#network192.168.1.0/24area0
永久性保存配置:
site-A-RTR(config-router)#dowrite
针对site-B,也重复类似的OSPF配置:
site-B-RTR(config-router)#network10.10.10.0/30area0
site-B-RTR(config-router)#network172.16.1.0/24area0
site-B-RTR(config-router)#dowrite
OSPF邻居现在应该会出现。只要ospfd在运行,通过vtysh外壳所作的任何与OSPF有关的配置变更都会立即生效,没必要重启ospfd。
在下一个部分,我们将验证已安装的Quagga环境。
验证
1.用ping来测试
首先,你应该能够从site-A来ping检测site-B的局域网了网。确保你的防火墙没有阻止ping检测流量。
[root@site-A-RTR~]#ping172.16.1.1-c2
2.检查路由表
内核和Quagga路由表里面应该都有必要的路由。
[root@site-A-RTR~]#iproute
10.10.10.0/30deveth0protokernelscopelinksrc10.10.10.1
172.16.1.0/30via10.10.10.2deveth0protozebrametric20
192.168.1.0/24deveth1protokernelscopelinksrc192.168.1.1
[root@site-A-RTR~]#vtysh
site-A-RTR#showiproute
Codes:K-kernelroute,C-connected,S-static,R-RIP,O-OSPF,
I-ISIS,B-BGP,>-selectedroute,*-FIBroute
O10.10.10.0/30[110/10]isdirectlyconnected,eth0,00:14:29
C>*10.10.10.0/30isdirectlyconnected,eth0
C>*127.0.0.0/8isdirectlyconnected,lo
O>*172.16.1.0/30[110/20]via10.10.10.2,eth0,00:14:14
C>*192.168.1.0/24isdirectlyconnected,eth1
3.验证OSPF邻居和路由器
在vtysh外壳里面,你可以检查必要的邻居有没有出现,是否记住合适的路由。
[root@site-A-RTR~]#vtysh
site-A-RTR#showipospfneighbor
以上就是使用Quagga配置基本的OSPF。通常来说,Quagga让我们很容易配置普通的Linux设备,以便支持OSPF、RIP或BGP等动态路由协议。支持Quagga的设备能够与你网络中可能拥有的其他任何路由器进行联系、交换路由。
由于Quagga支持几种主要的开放标准路由协议,它在许多场景下可能是优先的选择。更棒的是,Quagga的命令行接口与思科或瞻博等各大路由器厂商的命令行接口几乎一样;这样一来,部署和维护设备Quagga设备就显得非常容易。谢谢阅读,希望能帮到大家,请继续关注,我们会努力分享更多优秀的文章。