Redundant routing (ativo / backup) no linux

1

Atualmente, estou tentando configurar um roteamento redundante no RHEL 5. O objetivo de destino é ter uma rota principal para uma sub-rede e uma rota de backup para essa sub-rede, a ser usada somente se o gateway da rota principal se tornar inacessível.

Alguma ideia de como conseguir isso? A integração com arquivos padrão do RHEL é uma vantagem aqui:)

Agradecemos antecipadamente

    
por Henry-Nicolas Tourneur 20.02.2014 / 14:18

2 respostas

2

Você pode usar o quagga e o OSPF

# yum info quagga
Loaded plugins: changelog, fastestmirror, presto, security, versionlock
Loading mirror speeds from cached hostfile
 * base: ftp.colocall.net
 * epel: ftp.colocall.net
 * extras: ftp.colocall.net
 * ius: ius.cu.be
 * rpmforge: ftp.colocall.net
 * updates: ftp.colocall.net
Available Packages
Name        : quagga
Arch        : x86_64
Version     : 0.99.15
Release     : 7.el6_3.2
Size        : 1.1 M
Repo        : base
Summary     : Routing daemon
URL         : http://www.quagga.net
License     : GPLv2+
Description : Quagga is a free software that manages TCP/IP based routing
            : protocol. It takes multi-server and multi-thread approach to resolve
            : the current complexity of the Internet.
            :
            : Quagga supports BGP4, BGP4+, OSPFv2, OSPFv3, RIPv1, RIPv2, and RIPng.
            :
            : Quagga is intended to be used as a Route Server and a Route Reflector. It is
            : not a toolkit, it provides full routing power under a new architecture.
            : Quagga by design has a process for each protocol.
            :
            : Quagga is a fork of GNU Zebra.

E use peso diferente (custo) para cada gateway

router1.example.net# conf t
router1.example.net(config)# int tun0
router1.example.net(config-if)# ip ospf authentication message-digest
router1.example.net(config-if)# ip ospf message-digest-key 1 md5 SHdJLapbQ1
router1.example.net(config-if)# ip ospf cost 10
router1.example.net(config-if)# write
Configuration saved to /etc/quagga/ospfd.conf

router1.example.net# conf t
router1.example.net(config)# int tun1
router1.example.net(config-if)# ip ospf authentication message-digest
router1.example.net(config-if)# ip ospf message-digest-key 1 md5 SHdJLapbQ1
router1.example.net(config-if)# ip ospf cost 20
router1.example.net(config-if)# write
Configuration saved to /etc/quagga/ospfd.conf
    
por 20.02.2014 / 15:25
0

Uau, legal, nunca ouvi falar de quagga. Eu teria feito isso old school e script-lo e executá-lo fora do cron :) (MUITO KLUDGY)

algo como criar dois arquivos primeiro.

# cat /root/route1.txt
1.1.1.1
# cat /root/route2.txt
2.2.2.2

então um script como este fora do cron (ou em um loop "while true")

#!/bin/bash

route1='cat /root/route1.txt'
route2='cat /root/route2.txt'

$status='ping -n -c 1 -q $route1 | grep -c "1 received"'
if [ "$status" == "1" ]; 
then 
    echo "good stuff" > /dev/null
else 
    echo "bad stuff" > /dev/null
    route del [rest of command to delete current default $route1]
    route add default gateway $route2
    echo "$route1" > /root/route2.txt
    echo "$route2" > /root/route1.txt
fi

Como eu disse, muito kludgy né? :)

    
por 21.02.2014 / 01:51