天天看點

想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器

想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器

本教程中,我們将連接配接假設之間具有專線連接配接的兩個分支機構網絡(例如,192.168.1.0/24和172.17.1.0/24)。

想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器

我們的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 守護程序。

<a target="_blank"></a>

我們使用yum安裝quagga。

# yum install quagga

# setsebool -p zebra_write_config 1

如果沒有做這個修改,在我們嘗試在quagga指令行中儲存配置的時候看到如下錯誤。

can't open configuration file /etc/quagga/zebra.conf.os1uu5.

安裝完quagga後,我們要配置必要的對等ip位址,并更新ospf設定。quagga自帶了一個指令行稱為vtysh。vtysh裡面用到的quagga指令與主要的路由器廠商如思科和juniper是相似的。

我們首先建立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(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)# do show interface

inet 10.10.10.1/30 broadcast 10.10.10.3

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守護程序。

我們首先建立ospf配置檔案,并啟動ospf守護程序:

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

# service ospfd start

# chkconfig ospfd on

現在啟動vtysh指令行來繼續ospf配置:

輸入路由配置模式:

site-a-rtr(config)# router ospf

可選配置路由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設定。

首先你應該可以從site-a ping同site-b的lan子網。確定你的防火牆沒有阻止ping的流量。

[root@site-a-rtr ~]# ping 172.16.1.1 -c 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, &gt; - selected route, * - fib route

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

c&gt;* 10.10.10.0/30 is directly connected, eth0

c&gt;* 127.0.0.0/8 is directly connected, lo

o&gt;* 172.16.1.0/30 [110/20] via 10.10.10.2, eth0, 00:14:14

c&gt;* 192.168.1.0/24 is directly connected, eth1

在vtysh指令行中,你可以檢查必要的鄰居是否線上與是否已經學習了合适的路由。

site-a-rtr# show ip ospf neighbor

想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器想玩路由器嗎?使用 Quagga 将你的 CentOS 變成 OSPF 路由器

本教程中,我們将重點放在使用quagga配置基本的ospf。在一般情況下,quagga能讓我們能夠輕松在一台普通的linux機器上配置動态路由協定,如ospf、rip或bgp。啟用了quagga的機器可以與你網絡中的其他路由器進行通信和交換路由資訊。由于它支援主要的開放标準的路由協定,它或許是許多情況下的首選。更重要的是,quagga的指令行界面與主要路由器廠商如思科和juniper幾乎是相同的,這使得部署和維護quagga機器變得非常容易。

希望這些對你們有幫助。

原文釋出時間:2014-11-15

本文來自雲栖合作夥伴“linux中國”

繼續閱讀