Subversion Repositories ALCASAR

Rev

Rev 221 | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log

Rev 221 Rev 328
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