想玩路由器吗?使用 Quagga 将你的 CentOS 变成 OSPF 路由器

简介:

想玩路由器吗?使用 Quagga 将你的 CentOS 变成 OSPF 路由器

Quagga是一个开源路由软件套件,可以将Linux变成支持如RIP、OSPF、BGP和IS-IS等主要路由协议的路由器。它具有对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包括了几个协同工作的守护进程。在本教程中,我们将重点建立以下守护进程。

  1. Zebra: 核心守护进程,负责内核接口和静态路由。
  2. Ospfd: IPv4 OSPF 守护进程。

在CentOS上安装Quagga

我们使用yum安装Quagga。


  
  
  1. # yum install quagga

在CentOS7,SELinux默认会阻止quagga将配置文件写到/usr/sbin/zebra。这个SELinux策略会干扰我们接下来要介绍的安装过程,所以我们要禁用此策略。对于这一点,无论是关闭SELinux(这里不推荐),还是如下启用“zebrawriteconfig”都可以。如果你使用的是CentOS 6的请跳过此步骤。


  
  
  1. # setsebool -P zebra_write_config 1

如果没有做这个修改,在我们尝试在Quagga命令行中保存配置的时候看到如下错误。


  
  
  1. Can't open configuration file /etc/quagga/zebra.conf.OS1Uu5.

安装完Quagga后,我们要配置必要的对等IP地址,并更新OSPF设置。Quagga自带了一个命令行称为vtysh。vtysh里面用到的Quagga命令与主要的路由器厂商如思科和Juniper是相似的。

步骤 1: 配置 Zebra

我们首先创建Zebra配置文件,并启用Zebra守护进程。


  
  
  1. # cp /usr/share/doc/quagga-XXXXX/zebra.conf.sample /etc/quagga/zebra.conf
  2. # service zebra start
  3. # chkconfig zebra on

启动vtysh命令行:


  
  
  1. # vtysh

首先,我们为Zebra配置日志文件。输入下面的命令进入vtysh的全局配置模式:


  
  
  1. site-A-RTR# configure terminal

指定日志文件位置,接着退出模式:


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

永久保存配置:


  
  
  1. site-A-RTR# write

接下来,我们要确定可用的接口并按需配置它们的IP地址。


  
  
  1. site-A-RTR# show interface


  
  
  1. Interface eth0 is up, line protocol detection is disabled
  2. . . . . .
  3. Interface eth1 is up, line protocol detection is disabled
  4. . . . . .

配置eth0参数:


  
  
  1. site-A-RTR# configure terminal
  2. site-A-RTR(config)# interface eth0
  3. site-A-RTR(config-if)# ip address 10.10.10.1/30
  4. site-A-RTR(config-if)# description to-site-B
  5. site-A-RTR(config-if)# no shutdown

继续配置eth1参数:


  
  
  1. site-A-RTR(config)# interface eth1
  2. site-A-RTR(config-if)# ip address 192.168.1.1/24
  3. site-A-RTR(config-if)# description to-site-A-LAN
  4. site-A-RTR(config-if)# no shutdown

现在验证配置:


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


  
  
  1. Interface eth0 is up, line protocol detection is disabled
  2. . . . . .
  3. inet 10.10.10.1/30 broadcast 10.10.10.3
  4. . . . . .
  5. Interface eth1 is up, line protocol detection is disabled
  6. . . . . .
  7. inet 192.168.1.1/24 broadcast 192.168.1.255
  8. . . . . .


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


  
  
  1. Interface Status Protocol Description
  2. eth0 up unknown to-site-B
  3. eth1 up unknown to-site-A-LAN

永久保存配置:


  
  
  1. 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守护进程:


  
  
  1. # cp /usr/share/doc/quagga-XXXXX/ospfd.conf.sample /etc/quagga/ospfd.conf
  2. # service ospfd start
  3. # chkconfig ospfd on

现在启动vtysh命令行来继续OSPF配置:


  
  
  1. # vtysh

输入路由配置模式:


  
  
  1. site-A-RTR# configure terminal
  2. site-A-RTR(config)# router ospf

可选配置路由id:


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

添加在OSPF中的网络:


  
  
  1. site-A-RTR(config-router)# network 10.10.10.0/30 area 0
  2. site-A-RTR(config-router)# network 192.168.1.0/24 area 0

永久保存配置:


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

在site-B上重复和上面相似的OSPF配置:


  
  
  1. site-B-RTR(config-router)# network 10.10.10.0/30 area 0
  2. site-B-RTR(config-router)# network 172.16.1.0/24 area 0
  3. site-B-RTR(config-router)# do write

OSPF的邻居现在应该启动了。只要ospfd在运行,通过vtysh的任何OSPF相关配置的改变都会立即生效而不必重启ospfd。

下一节,我们会验证我们的Quagga设置。

验证

1. 通过ping测试

首先你应该可以从site-A ping同site-B的LAN子网。确保你的防火墙没有阻止ping的流量。


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

2. 检查路由表

必要的路由应该同时出现在内核与Quagga理由表中。


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


  
  
  1. 10.10.10.0/30 dev eth0 proto kernel scope link src 10.10.10.1
  2. 172.16.1.0/30 via 10.10.10.2 dev eth0 proto zebra metric 20
  3. 192.168.1.0/24 dev eth1 proto kernel scope link src 192.168.1.1


  
  
  1. [root@site-A-RTR ~]# vtysh
  2. site-A-RTR# show ip route


  
  
  1. Codes: K - kernel route, C - connected, S - static, R - RIP, O - OSPF,
  2. I - ISIS, B - BGP, > - selected route, * - FIB route
  3.  
  4. O 10.10.10.0/30 [110/10] is directly connected, eth0, 00:14:29
  5. C>* 10.10.10.0/30 is directly connected, eth0
  6. C>* 127.0.0.0/8 is directly connected, lo
  7. O>* 172.16.1.0/30 [110/20] via 10.10.10.2, eth0, 00:14:14
  8. C>* 192.168.1.0/24 is directly connected, eth1

3. 验证OSPF邻居和路由

在vtysh命令行中,你可以检查必要的邻居是否在线与是否已经学习了合适的路由。


  
  
  1. [root@site-A-RTR ~]# vtysh
  2. site-A-RTR# show ip ospf neighbor

本教程中,我们将重点放在使用Quagga配置基本的OSPF。在一般情况下,Quagga能让我们能够轻松在一台普通的Linux机器上配置动态路由协议,如OSPF、RIP或BGP。启用了Quagga的机器可以与你网络中的其他路由器进行通信和交换路由信息。由于它支持主要的开放标准的路由协议,它或许是许多情况下的首选。更重要的是,Quagga的命令行界面与主要路由器厂商如思科和Juniper几乎是相同的,这使得部署和维护Quagga机器变得非常容易。

希望这些对你们有帮助。

原文发布时间:2014-11-15

本文来自云栖合作伙伴“linux中国”


目录
相关文章
|
网络协议 Unix Linux
CentOS7下利用FRR路由套件实现OSPF动态路由组网
CentOS7下利用FRR路由套件实现OSPF动态路由组网
1320 0
CentOS7下利用FRR路由套件实现OSPF动态路由组网
|
1月前
|
存储 安全 Linux
CentOS安装SeaweedFS
通过上述步骤,您应该能够在CentOS系统上成功安装并启动SeaweedFS。记住,根据实际部署规模和需求,可能还需要进一步调整配置参数和优化网络布局。SeaweedFS的灵活性和扩展性意味着随着使用深入,您可能需要探索更多高级配置和管理策略。
104 64
|
1月前
|
存储 安全 Linux
CentOS安装SeaweedFS
通过上述步骤,您应该能够在CentOS系统上成功安装并启动SeaweedFS。记住,根据实际部署规模和需求,可能还需要进一步调整配置参数和优化网络布局。SeaweedFS的灵活性和扩展性意味着随着使用深入,您可能需要探索更多高级配置和管理策略。
112 61
|
7天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
|
8天前
|
SQL 存储 Linux
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第7天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统要求检查与准备、配置安装源、安装 SQL Server 2019、配置 SQL Server 以及数据库初始化(可选)。通过这些步骤,你可以成功安装并初步配置 SQL Server 2019,进行简单的数据库操作。
|
1月前
|
Linux 网络安全 数据安全/隐私保护
Linux系统之Centos7安装cockpit图形管理界面
【10月更文挑战第12天】Linux系统之Centos7安装cockpit图形管理界面
69 1
Linux系统之Centos7安装cockpit图形管理界面
|
15天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
49 3
|
16天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
31 2
|
1月前
|
NoSQL 数据可视化 Linux
redis学习四、可视化操作工具链接 centos redis,付费Redis Desktop Manager和免费Another Redis DeskTop Manager下载、安装
本文介绍了Redis的两个可视化管理工具:付费的Redis Desktop Manager和免费的Another Redis DeskTop Manager,包括它们的下载、安装和使用方法,以及在使用Another Redis DeskTop Manager连接Redis时可能遇到的问题和解决方案。
119 1
redis学习四、可视化操作工具链接 centos redis,付费Redis Desktop Manager和免费Another Redis DeskTop Manager下载、安装