利用Quagga软件 将你的CentOS设备变成OSPF路由器的方法

Quagga是一款开源路由软件套件,它可以用来将你的Linux设备变成一个功能完备的路由器,支持几种主要的路由协议,比如RIP、OSPF、BGP或ISIS路由器。它完全为IPv4和IPv6作好了准备,还支持路由/前缀过滤。万一你生产环境中的路由器出现了故障,手头又没有备用的路由器,死等替换件送来,Quagga就能派得上大用场。只要配置得当,Quagga甚至可以配置成生产环境中的路由器。

我们在本教程中将连接两个假设的分支机构网络(比如192.168.1.0/24和172.17.1.0/24),这两个网络之间采用了一条专用的链路。

我们的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:IPv4 OSPF后台程序。

将Quagga安装到CentOS上

我们首先使用yum来安装Quagga。

# yum install quagga

在CentOS 7上,SELinux在默认情况下阻止/usr/sbin/zebra写入到其配置目录中。这个SELinux策略干扰了我们所要描述的安装过程,于是我们想禁止该策略。为此,关闭SELinux(不推荐),或者启用“zebra_write_config”布尔表达式,如下所示。如果你使用CentOS 6,可以跳过这一步。

# setsebool -P zebra_write_config 1

要是不进行这种更改,我们在试图从Quagga的命令外壳里面保存Zebra配置时,就会看到下列错误。

Can't open configuration file /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

# service zebra start

# chkconfig zebra on

启动vtysh命令外壳:

# vtysh

首先,我们为Zebra配置日志文件。为此,输入下列内容,进入vtysh中的全局配置模式:

site-A-RTR# configure terminal

并指定日志文件位置,然后退出该模式:

site-A-RTR(config)# log file /var/log/quagga/quagga.log

site-A-RTR(config)# exit

永久性保存配置:

site-A-RTR# write

下一步,我们在必要时确定可用接口,然后配置IP地址。

site-A-RTR# show interface

Interface eth0 is up, line protocol detection is disabled

. . . . .

Interface eth1 is up, line protocol detection is disabled

. . . . .

配置eth0参数:

site-A-RTR# configure terminal

site-A-RTR(config)# interface eth0

site-A-RTR(config-if)# ip address 10.10.10.1/30

site-A-RTR(config-if)# description to-site-B

site-A-RTR(config-if)# no shutdown

继续配置eth1参数:

site-A-RTR(config)# interface eth1

site-A-RTR(config-if)# ip address 192.168.1.1/24

site-A-RTR(config-if)# description to-site-A-LAN

site-A-RTR(config-if)# no shutdown

现在验证配置:

site-A-RTR(config-if)# do show interface

Interface eth0 is up, line protocol detection is disabled

. . . . .

inet 10.10.10.1/30 broadcast 10.10.10.3

. . . . .

Interface eth1 is up, line protocol detection is disabled

. . . . .

inet 192.168.1.1/24 broadcast 192.168.1.255

. . . . .

site-A-RTR(config-if)# do show interface description

Interface Status Protocol Description

eth0 up unknown to-site-B

eth1 up unknown to-site-A-LAN

永久性保存配置:

site-A-RTR(config-if)# do write

针对site-B服务器,也重复IP地址配置这个步骤。

要是一切顺利,你应该能够从site-A服务器来ping检测site-B的对等IP 10.10.10.2。

请注意:一旦Zebra后台程序已启动,用vtysh的命令行接口进行的任何更改会立即生效。不需要在配置变更后重启Zebra后台程序。

第2个阶段:配置OSPF

我们先创建一个OSPF配置文件,然后启动OSPF后台程序:

# cp /usr/share/doc/quagga-XXXXX/ospfd.conf.sample /etc/quagga/ospfd.conf

# service ospfd start

# chkconfig ospfd on

现在启动vtysh外壳,继续进行OSPF配置:

# vtysh

进入路由器配置模式:

site-A-RTR# configure terminal

site-A-RTR(config)# router ospf

还可以手动设置router-id:

site-A-RTR(config-router)# router-id 10.10.10.1

添加将参与OSPF的网络:

site-A-RTR(config-router)# network 10.10.10.0/30 area 0

site-A-RTR(config-router)# network 192.168.1.0/24 area 0

永久性保存配置:

site-A-RTR(config-router)# do write

针对site-B,也重复类似的OSPF配置:

site-B-RTR(config-router)# network 10.10.10.0/30 area 0

site-B-RTR(config-router)# network 172.16.1.0/24 area 0

site-B-RTR(config-router)# do write

OSPF邻居现在应该会出现。只要ospfd在运行,通过vtysh外壳所作的任何与OSPF有关的配置变更都会立即生效,没必要重启ospfd。

在下一个部分,我们将验证已安装的Quagga环境。

验证

1. 用ping来测试

首先,你应该能够从site-A来ping检测site-B的局域网了网。确保你的防火墙没有阻止ping检测流量。

[root@site-A-RTR ~]# ping 172.16.1.1 -c 2

2. 检查路由表

内核和Quagga路由表里面应该都有必要的路由。

[root@site-A-RTR ~]# ip route

10.10.10.0/30 dev eth0 proto kernel scope link src 10.10.10.1

172.16.1.0/30 via 10.10.10.2 dev eth0 proto zebra metric 20

192.168.1.0/24 dev eth1 proto kernel scope link src 192.168.1.1

[root@site-A-RTR ~]# vtysh

site-A-RTR# show ip route

Codes: K - kernel route, C - connected, S - static, R - RIP, O - OSPF,

I - ISIS, B - BGP, > - selected route, * - FIB route

O 10.10.10.0/30 [110/10] is directly connected, eth0, 00:14:29

C>* 10.10.10.0/30 is directly connected, eth0

C>* 127.0.0.0/8 is directly connected, lo

O>* 172.16.1.0/30 [110/20] via 10.10.10.2, eth0, 00:14:14

C>* 192.168.1.0/24 is directly connected, eth1

3. 验证OSPF邻居和路由器

在vtysh外壳里面,你可以检查必要的邻居有没有出现,是否记住合适的路由。

[root@site-A-RTR ~]# vtysh

site-A-RTR# show ip ospf neighbor

以上就是使用Quagga配置基本的OSPF。通常来说,Quagga让我们很容易配置普通的Linux设备,以便支持OSPF、RIP或BGP等动态路由协议。支持Quagga的设备能够与你网络中可能拥有的其他任何路由器进行联系、交换路由。

由于Quagga支持几种主要的开放标准路由协议,它在许多场景下可能是优先的选择。更棒的是,Quagga的命令行接口与思科或瞻博等各大路由器厂商的命令行接口几乎一样;这样一来,部署和维护设备Quagga设备就显得非常容易。谢谢阅读,希望能帮到大家,请继续关注脚本之家,我们会努力分享更多优秀的文章。

(0)

相关推荐

  • 海外党如何利用Golink软件取消国产电视剧综艺节目的版权限制?

    相信很多小伙伴都是海外党,如果我们想要看国产电视剧综艺节目时该怎么做呢?通过Golink软件就能解决这个问题,下面小编就来为大家具体介绍.具体如下:1. 首先,进入下图所示的Golink官网,扫描其中 ...

  • 利用PS软件放大照片后显示模糊了如何解决

    今天就跟大家介绍一下利用PS软件放大照片后显示模糊了的具体解决方法.1. 如图,打开电脑,选择使用PS软件打开一张图片,然后按键盘上的ctrl k组合键.2. 如图,在弹出的首选项窗口中,点击左下方的 ...

  • 朋友圈微商被黑:利用作弊软件制造骗局

    12月9日消息,火爆朋友圈的“微商”(主要指卖家借助微信销售)近期屡屡“被黑”。在被一些业内人士质疑“微商没有未来”后,日前网络又曝光了一组微商利用作弊软件制造假生意的截图,让人大跌眼镜。根据网络曝光 ...

  • 如何利用webps软件来旋转照片

    如果要对照片进行旋转,往往可以选择在webps中进行,十分简单快捷.接下来就由小编来告诉大家如何操作.具体如下:1. 1.第一步,打开电脑并在桌面上找到webps图标,点击打开.2. 2.第二步,点击 ...

  • 如何利用PrCC软件创造出视频透视效果

    当我们进行图片视频剪辑操作时,如果想要令观众有一种身临其境的感受的话,可以对其进行一些效果的添加.接下来就由小编来告诉大家如何添加视频透视效果.具体如下:1.首先假情景为电影观看电影,第一步,选择一张 ...

  • 如何利用Photoshop软件对文字添加冰火效果

    随着科技的发展,我们可以利用ps软件对文字添加各种各样的特效.接下来就由小编来告诉大家如何添加冰火文字效果.具体如下:1.第一步,先在ps中导入一张图片,再点击左侧工具栏中的横排文字蒙版工具选项.2. ...

  • 如何在电脑中利用格式工厂软件解压文件?

    相信很多小伙伴在日常办公中都会遇到很多压缩文件,如果我们想要解压这些文件该怎么做呢?方法很简单,下面小编就来为大家介绍.具体如下:1. 首先,在电脑上下载安装软件"格式工厂".2. ...

  • 怎么利用组策略设置阻止添加打印机设备

    今天,小编给大家介绍利用组策略设置阻止添加打印机设备的方法,希望对大家有所帮助.具体如下:1. 首先,请大家在自己的电脑中找到[本地组策略编辑器],点击进入它的主界面.2.第二步,接下来,请选择屏幕左 ...

  • 利用PR软件怎么给视频添加字幕

    今天给大家介绍一下利用PR软件怎么给视频添加字幕的具体操作步骤.1. 打开电脑上的PR软件,然后在页面中,选择新建项目2. 在弹出的窗口中,选择确定3. 接下来,同样确定4. 接下来,如图位置,右键, ...