Line 1... |
Line 1... |
1 |
#!/bin/bash
|
1 |
#!/bin/bash
|
2 |
# $Id: alcasar-load_balancing.sh 221 2010-08-31 06:55:40Z franck $
|
2 |
# $Id: alcasar-load_balancing.sh 328 2010-11-17 08:12:43Z franck $
|
3 |
|
3 |
|
4 |
# alcasar-load_balancing.sh Load-balance internet connection over two or more local links
|
4 |
# alcasar-load_balancing.sh Connection Internet au travers de 2 ou plusieurs liens internet
|
5 |
#
|
5 |
#
|
6 |
# Version: 0.8.0 - Wed, Sep 01, 2010
|
6 |
# Version: 0.9 - 17 Nov 2010
|
7 |
#
|
7 |
#
|
8 |
# by Author: BOUIJOUX Franck (3abTux) <3abtux@free.fr>
|
8 |
# by Author: BOUIJOUX Franck (3abTux) <3abtux@free.fr>
|
9 |
# en cours d'expérimentation et d 'écriture
|
9 |
# en cours d'expérimentation et d'écriture
|
10 |
#
|
- |
|
- |
|
10 |
# À optimiser pour une écriture plus
|
11 |
|
11 |
|
- |
|
12 |
# Définion des poids des routes : même poids --> alternance des connexions
|
12 |
# Définion des poids des routes
|
13 |
# sinon le poids le plus faible est prioritaire
|
13 |
WEIGHT1=1
|
14 |
WEIGHT1=1
|
14 |
WEIGHT2=1
|
15 |
WEIGHT2=1
|
15 |
#WEIGHT3=3
|
16 |
#WEIGHT3=3
|
16 |
|
17 |
|
17 |
# Set devices:
|
18 |
# Définition des interfaces :
|
18 |
DEV1=${1-eth0} # defaut eth0
|
19 |
DEV1=${1-eth0} # defaut eth0
|
19 |
DEV2=${2-eth0} # defaut eth0 mais peut être autre chose :-)
|
20 |
DEV2=${2-eth0} # defaut eth0 mais peut être autre chose :-)
|
20 |
DEV3=${3-eth0} # defaut eth0 mais peut être autre chose :-)
|
21 |
DEV3=${3-eth0} # defaut eth0 mais peut être autre chose :-)
|
21 |
|
22 |
|
22 |
# Trouver les adresses pour chaque interface
|
23 |
# Trouver les adresses pour chaque interface
|
23 |
IP1=`ifconfig $DEV1 | grep inet | awk '{ print $2 }' | awk -F: '{ print $2 }'`
|
24 |
IP1=`ifconfig $DEV1 | grep inet | awk '{ print $2 }' | awk -F: '{ print $2 }'`
|
24 |
IP2=`ifconfig $DEV2 | grep inet | awk '{ print $2 }' | awk -F: '{ print $2 }'`
|
25 |
IP2=`ifconfig $DEV2 | grep inet | awk '{ print $2 }' | awk -F: '{ print $2 }'`
|
25 |
#IP3=`ifconfig $DEV3 | grep inet | awk '{ print $2 }' | awk -F: '{ print $2 }'`
|
26 |
#IP3=`ifconfig $DEV3 | grep inet | awk '{ print $2 }' | awk -F: '{ print $2 }'`
|
26 |
|
27 |
|
27 |
# iTrouver les passerelles pour chaque interface
|
28 |
# Trouver les passerelles pour chaque interface { ne fonctionne pas bien avec une seule interface } --> forcer les passerelles !
|
28 |
#GW1=`route -n | grep $DEV1 | grep '^0.0.0.0' | awk '{ print $2 }'`
|
29 |
#GW1=`route -n | grep $DEV1 | grep '^0.0.0.0' | awk '{ print $2 }'`
|
29 |
#GW2=`route -n | grep $DEV2 | grep '^0.0.0.0' | awk '{ print $2 }'`
|
30 |
#GW2=`route -n | grep $DEV2 | grep '^0.0.0.0' | awk '{ print $2 }'`
|
30 |
GW1=192.168.1.6
|
31 |
GW1=192.168.1.6
|
31 |
GW2=192.168.1.1
|
32 |
GW2=192.168.1.1
|
32 |
#GW3=192.168.1.6
|
33 |
#GW3=192.168.1.6
|
33 |
|
34 |
|
34 |
echo "Acces internet depuis $DEV1: IP=$IP1 par la GW=$GW1"
|
35 |
echo "Acces internet depuis $DEV1: IP=$IP1 par la GW=$GW1"
|
35 |
echo " et depuis $DEV2: IP=$IP2 par la GW=$GW2"
|
36 |
echo " et depuis $DEV2: IP=$IP2 par la GW=$GW2"
|
36 |
#echo " et depuis $DEV3: IP=$IP3 par la GW=$GW3"
|
37 |
#echo " et depuis $DEV3: IP=$IP3 par la GW=$GW3"
|
37 |
|
38 |
|
38 |
# Definition des routes
|
39 |
# Mise en place des routes
|
39 |
|
40 |
|
40 |
# Tester si les tables existent sinon les créer
|
41 |
# Tester si les tables existent sinon les créer
|
41 |
if [ -z "`cat /etc/iproute2/rt_tables | grep '^252'`" ] ; then
|
42 |
if [ -z "`cat /etc/iproute2/rt_tables | grep '^252'`" ] ; then
|
42 |
echo "252 rt_dev1" >> /etc/iproute2/rt_tables
|
43 |
echo "252 rt_dev1" >> /etc/iproute2/rt_tables
|
43 |
fi
|
44 |
fi
|
Line 53... |
Line 54... |
53 |
# Tables de routage
|
54 |
# Tables de routage
|
54 |
ip route add default via $GW1 table rt_dev1
|
55 |
ip route add default via $GW1 table rt_dev1
|
55 |
ip route add default via $GW2 table rt_dev2
|
56 |
ip route add default via $GW2 table rt_dev2
|
56 |
#ip route add default via $GW3 table rt_dev3
|
57 |
#ip route add default via $GW3 table rt_dev3
|
57 |
|
58 |
|
58 |
# Créatin des règles
|
59 |
# Création des règles
|
59 |
ip rule add from $IP1 table rt_dev1
|
60 |
ip rule add from $IP1 table rt_dev1
|
60 |
ip rule add from $IP2 table rt_dev2
|
61 |
ip rule add from $IP2 table rt_dev2
|
61 |
#ip rule add from $IP3 table rt_dev3
|
62 |
#ip rule add from $IP3 table rt_dev3
|
62 |
|
63 |
|
63 |
# Effacer la route par défaut existante
|
64 |
# Effacer la route par défaut existante
|
64 |
if [ ! -z "`ip route show table main | grep 'nexthop'`" ] ; then
|
65 |
if [ ! -z "`ip route show table main | grep 'nexthop'`" ] ; then
|
65 |
ip route del default scope global
|
66 |
ip route del default scope global
|
66 |
fi
|
67 |
fi
|
67 |
|
68 |
|
68 |
# Alterne les liens basés sur chauqe route
|
69 |
# Alterne les liens basés sur chaque route
|
69 |
ip route add default scope global nexthop via $GW1 dev $DEV1 weight $WEIGHT1 \
|
70 |
ip route add default scope global nexthop via $GW1 dev $DEV1 weight $WEIGHT1 \
|
70 |
nexthop via $GW2 dev $DEV2 weight $WEIGHT2
|
71 |
nexthop via $GW2 dev $DEV2 weight $WEIGHT2
|
71 |
# nexthop via $GW3 dev $DEV3 weight $WEIGHT3
|
72 |
# nexthop via $GW3 dev $DEV3 weight $WEIGHT3
|
72 |
|
73 |
|
73 |
|
74 |
|