LVS负载均衡-DR模式-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

LVS负载均衡-DR模式

简介:

环境:

DIR:eth0   172.16.115.100     eth0:0   172.16.115.200(vip)

RS1:eth0   172.16.115.157         lo:0   172.16.115.200(vip)

RS2:eth0   172.16.115.202         lo:0   172.16.115.200(vip)

   wKioL1izoKWAfutAAAA3AzQDZhY541.png

DIR主机

1. 安装lvs软件包ipvsadm和nginx,编辑hosts文件/etc/hosts,修改hostname为dr

    阿里云扩展源wget http://mirrors.aliyun.com/repo/epel-6.repo  -P /etc/yum.repos.d/

    命令 yum install -y ipvsadm  nginx


2. 编写DR模式的脚本vim /usr/local/sbin/lvs_dr.sh

    内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
  #! /bin/bash
    #开启转发规则
    echo 1 > /proc/sys/net/ipv4/ip_forward
      
    #定义变量参数
    ipv=/sbin/ipvsadm
    vip=172.16.115.200
    rs1=172.16.115.157
    rs2=172.16.115.202
     
    #配置虚拟IP,添加路由
    ifconfig eth0:0 $vip broadcast $vip netmask 255.255.255.255 up
    route add -host $vip dev eth0:0
     
    #设置dr和rs主机,g表示DR模式
    $ipv -C
    $ipv -A -t $vip:80 -s rr
    $ipv -a -t $vip:80 -r $rs1:80 -g -w 1
    $ipv -a -t $vip:80 -r $rs2:80 -g -w 1


3. 执行脚本/usr/local/sbin/lvs_dr.sh;查看ipvsadm生成的转发规则

    命令 sh /usr/local/sbin/lvs_dr.sh

    命令 ipvsadm -ln

 wKioL1iziZPRyCKOAAAiaS_M9y8301.png

  

RS1/RS2主机

1. 编写脚本vim /usr/local/sbin/lvs_rs.sh

    内容:

1
2
3
4
5
6
7
8
9
10
11
12
13
  #! /bin/bash
    #指定vip是在回环地址地址上;子网掩码全设255,表明只发不回
    vip=172.16.115.200
    ifconfig lo:0 $vip broadcast $vip netmask 255.255.255.255 up
      
    #添加路由
    route add -host $vip lo:0
     
    #调整内核参数
    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/all/arp_ignore
    echo "2" /proc/sys/net/ipv4/conf/all/arp_announce


    解释arp_ignore,接受来自其他主机arp请求的响应级别

              当主机有两块网卡1.1.1.1和2.2.2.2,客户机通过1.1.1.1访问2.2.2.2时:

              1)arp_ignore=0,客户机可以收到响应,源IP为2.2.2.2,但是MAC是1.1.1.1的

              2)arp_ignore=1,主机拒绝,客户机无法收到响应

              本实验中:dir的两块网卡,共用在eth0上;rs的两块网卡分别为eth0和lo,参数被拒绝;所以只有dir能收到vip的请求


     arp_announce,arp通告级别

               每台主机加入网络之后,就会向网络中通告自己的IP和mac对应信息,方便其他主机和自己通信:

               1)arp_announce=0,告知网络中本机所有接口的任何地址信息

               2)arp_announce=2,只向目标网络通告与其网络相匹配的地址信息

               本实验中:rs的vip只处理来自DR转发响应,所以设置为2


2. RS1和RS2分别启动脚本/usr/local/sbin/lvs_rs.sh

    说明:执行成功之后,会在回环地址网卡上生产一个虚拟ip 172.16.115.200

    命令 sh  /usr/local/sbin/lvs_rs.sh

 wKiom1izicmgYVYiAABr8BAxmuw799.png



测试

1.  分别修改rs1和rs2首页内容,并启动Nginx

     rs1:echo "hello,rs1" > /usr/share/nginx/html/index.html

     rs2:echo "hello,rs2" > /usr/share/nginx/html/index.html

     命令 /etc/init.d/nginx start


2. 用客户机curl测试虚拟ip172.16.115.200

    命令 curl 172.16.115.200

    结果:权重1:1交替出现RS1和RS2内容

 wKiom1izifajIfImAAAizI9CXUU809.pngspacer.gif


3. dir上修改配置文件/usr/local/sbin/lvs_dr.sh,设置权重

    说明:配置文件需先down掉eth0:0,再开启

    内容:


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
  #! /bin/bash
    echo 1 > /proc/sys/net/ipv4/ip_forward
     
    ipv=/sbin/ipvsadm
    vip=172.16.115.200
    rs1=172.16.115.157
    rs2=172.16.115.202
     
    ifconfig eth0:0 down
    ifconfig eth0:0 $vip broadcast $vip netmask 255.255.255.255 up
    route add -host $vip dev eth0:0
     
    $ipv -C
    $ipv -A -t $vip:80 -s wrr
    $ipv -a -t $vip:80 -r $rs1:80 -g -w 4
    $ipv -a -t $vip:80 -r $rs2:80 -g -w 1


    结果:4次rs1和1次rs2交替出现

 wKiom1izihiycM60AAAiRgJ78Y4739.pngspacer.gif










本文转自 huangzp168 51CTO博客,原文链接:http://blog.51cto.com/huangzp/1901552,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章
最新文章
相关文章