LVS-DR集群构建脚本

目录

一.在LVS主节点上的配置

 二.真实设备RS上的配置

三.客户端测试


一.在LVS主节点上的配置

[root@main ~]# cat /etc/init.d/lvs-dr 
#!/bin/bash 
LOCK=/var/lock/ipvsadm.lock
VIP=192.168.2.100   #修改为自己的VIP地址
RIP1=192.168.2.131   #第一个真实设备的地址
RIP2=192.168.2.132   #第二个真实设备的地址
DipName=ens33   #自己网卡设备的名称
. /etc/rc.d/init.d/functions
start() {
    PID=`ipvsadm -Ln | grep ${VIP} | wc -l`
    if [ $PID -gt 0 ];
    then
        echo "The LVS-DR Server is already running !"
    else
        #VIP的相关设置
        /sbin/ifconfig ${DipName}:130 $VIP broadcast $VIP netmask 255.255.255.0 up
        /sbin/route add -host $VIP dev ${DipName}:130
        /sbin/ipvsadm -C
        #这里是进行LV-DR的配置,若是需要修改调度方式、权重、主机地址等是在这里更改
        /sbin/ipvsadm -At $VIP:80 -s rr
        /sbin/ipvsadm -at $VIP:80 -r $RIP1:80 -g
        /sbin/ipvsadm -at $VIP:80 -r $RIP2:80 -g
        /bin/touch $LOCK
        echo "starting LVS-DR Server is ok !"
    fi
}
stop() {
    /sbin/ipvsadm -C
    /sbin/route del -host $VIP dev ${DipName}:130
    /sbin/ifconfig ${DipName}:130 down >/dev/null
    rm -rf $LOCK
    echo "stopping LVS-DR server is ok !"
}
status() {
    if [ -e $LOCK ];
    then
        echo "The LVS-DR Server is already running !"
    else
        echo "The LVS-DR Server is not running !"
    fi
}
case "$1" in
    start)
        start
        ;;
    stop)
        stop
        ;;
    restart)
        stop
        start
        ;;
    status)
        status
        ;;
    *)
        echo "Usage: $1 {start|stop|restart|status}"
        exit 1
esac
exit 0
​
[root@main ~]# systemctl daemon-reload
[root@main ~]# ipvsadm -Ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
TCP  192.168.2.100:80 rr
  -> 192.168.2.131:80             Route   1      0          0         
  -> 192.168.2.132:80             Route   1      0          0    

 二.真实设备RS上的配置

绑定VIP。这一步操作可以将此脚本保存到主节点上,通过ansible的copy、shell、service模块等传到各个节点上应用即可

[root@servera ~]# cat /etc/init.d/lvs-dr 
#!/bin/bash
LOCK=/var/lock/ipvsadm.lock
VIP=192.168.2.100   #要绑定的VIP的地址
. /etc/rc.d/init.d/functions
start() {
    PID=`ifconfig | grep lo:130 | wc -l`
    if [ $PID -ne 0 ];
    then
        echo "The LVS-DR-RIP Server is already running !"
    else
        /sbin/ifconfig lo:130 $VIP netmask 255.255.255.255 broadcast $VIP up
        /sbin/route add -host $VIP dev lo:130
        echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
        echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
        echo "1" >/proc/sys/net/ipv4/conf/ens33/arp_ignore   #修改为自己的网卡设备名称
        echo "2" >/proc/sys/net/ipv4/conf/ens33/arp_announce
        echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
        echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
        /bin/touch $LOCK
        echo "starting LVS-DR-RIP server is ok !"
    fi
}
stop() {
    /sbin/route del -host $VIP dev lo:130
    /sbin/ifconfig lo:130 down >/dev/null
    echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
    echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
    echo "0" >/proc/sys/net/ipv4/conf/ens33/arp_ignore   #修改
    echo "0" >/proc/sys/net/ipv4/conf/ens33/arp_announce
    echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
    echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
    rm -rf $LOCK
    echo "stopping LVS-DR-RIP server is ok !"
}
status() {
    if [ -e $LOCK ];
    then
        echo "The LVS-DR-RIP Server is already running !"
    else
        echo "The LVS-DR-RIP Server is not running !"
    fi
}
case "$1" in
    start)
        start
        ;;
    stop)
        stop
        ;;
    restart)
        stop
        start
        ;;
    status)
        status
        ;;
    *)
        echo "Usage: $1 {start|stop|restart|status}"
        exit 1
esac
exit 0
[root@servera ~]# systemctl daemon-reload 
[root@servera ~]# route -n
Kernel IP routing table
Destination     Gateway         Genmask         Flags Metric Ref    Use Iface
0.0.0.0         192.168.2.1     0.0.0.0         UG    100    0        0 ens33
172.16.76.0     192.168.2.130   255.255.255.192 UG    0      0        0 tunl0
172.16.173.192  192.168.2.132   255.255.255.192 UG    0      0        0 tunl0
172.16.196.192  0.0.0.0         255.255.255.192 U     0      0        0 *
192.168.2.0     0.0.0.0         255.255.255.0   U     100    0        0 ens33
192.168.2.100   0.0.0.0         255.255.255.255 UH    0      0        0 lo
#添加成功

三.客户端测试

[root@serverc ~]# for ((i=1;i<=10;i++)) ; do curl 192.168.2.100; done
192.168.2.132
192.168.2.131
192.168.2.132
192.168.2.131
192.168.2.132
192.168.2.131
192.168.2.132
192.168.2.131
192.168.2.132
192.168.2.131
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

树下一少年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值