muri 发表于 2018-12-31 08:18:26

18.11

  18.11 LVS DR模式搭建
  1 准备三台机器
  分发器(也叫调度器,简写为dir)192.168.189.128
  rs1 192.168.189.129
  rs2 192.168.189.130
  每台机器上(包括dir,所有rs)都设置vip 192.168.189.200
  2 dir上编写脚本
#vim /usr/local/sbin/lvs_dr.sh
#! /bin/bash
echo 1 > /proc/sys/net/ipv4/ip_forward
ipv=/usr/sbin/ipvsadm
vip=192.168.189.200
rs1=192.168.189.129
rs2=192.168.189.130
#注意这里的网卡名字
ifdown ens33
ifup ens33
ifconfig ens33:2 $vip broadcast $vip netmask 255.255.255.255 up
route add -host $vip dev ens33:2
$ipv -C
$ipv -A -t $vip:80 -s wrr
$ipv -a -t $vip:80 -r $rs1:80 -g -w 1
$ipv -a -t $vip:80 -r $rs2:80 -g -w 1  参数解释:
  echo 1 > /proc/sys/net/ipv4/ip_forward 打开端口转发
  ipv=/usr/sbin/ipvsadm
  vip=192.168.189.200
  rs1=192.168.189.129
  rs2=192.168.189.130
  设置各参数的变量,变量代替ip
  ifconfig ens33:2 $vip broadcast $vip netmask 255.255.255.255 up
  ifconfig设置一个网卡的虚拟网卡
  绑定vip的命令配置,ens33:2
  route add -host $vip dev ens33:2
  设置网关
  3 dir上启动脚本
  # sh !$
  sh /usr/local/sbin/lvs_dr.sh
  成功断开设备 'ens33'。
  连接已成功激活(D-Bus 活动路径:/org/freedesktop/NetworkManager/ActiveConnection/17)
  4 编写rs上的脚本
  两台rs上也编写脚本 vim /usr/local/sbin/lvs_rs.sh//内容如下
  注意rs1上的脚本名是lvs_rs1.sh,rs2上的脚本名是lvs_rs2.sh
  rs1上,
# vim /usr/local/sbin/lvs_rs.sh
#/bin/bash
vip=192.168.189.200
#把vip绑定在lo上,是为了实现rs直接把结果返回给客户端
ifdown lo
ifup lo
ifconfig lo:0 $vip broadcast $vip netmask 255.255.255.255 up
route add -host $vip lo:0
#以下操作为更改arp内核参数,目的是为了让rs顺利发送mac地址给客户端
#参考文档www.cnblogs.com/lgfeng/archive/2012/10/16/2726308.html
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  rs2上,
# vim /usr/local/sbin/lvs_rs2.sh
#/bin/bash
vip=192.168.189.200
#把vip绑定在lo上,是为了实现rs直接把结果返回给客户端
ifdown lo
ifup lo
ifconfig lo:0 $vip broadcast $vip netmask 255.255.255.255 up
route add -host $vip lo:0
#以下操作为更改arp内核参数,目的是为了让rs顺利发送mac地址给客户端
#参考文档www.cnblogs.com/lgfeng/archive/2012/10/16/2726308.html
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内核参数,目的是为了让rs顺利发送mac地址给客户端
  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
  5 检查vip是否绑定了在rs1,rs2,dir上
  dir,
# ip add
1: lo:mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: ens33:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:15:53:53 brd ff:ff:ff:ff:ff:ff
    inet 192.168.189.128/24 brd 192.168.189.255 scope global ens33
       valid_lft forever preferred_lft forever
    inet 192.168.189.200/32 brd 192.168.189.200 scope global ens33:2
       valid_lft forever preferred_lft forever
    inet 192.168.189.150/24 brd 192.168.189.255 scope global secondary ens33:0
       valid_lft forever preferred_lft forever
    inet6 fe80::243c:86d7:d85e:224d/64 scope link
       valid_lft forever preferred_lft forever
3: ens37:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:15:53:5d brd ff:ff:ff:ff:ff:ff
    inet 192.168.149.128/24 brd 192.168.149.255 scope global dynamic ens37
       valid_lft 1464sec preferred_lft 1464sec
    inet 192.168.149.147/24 brd 192.168.149.255 scope global secondary ens37
       valid_lft forever preferred_lft forever
    inet6 fe80::20c:29ff:fe15:535d/64 scope link
       valid_lft forever preferred_lft forever  rs1,
# ip add
1: lo:mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet 192.168.189.200/32 brd 192.168.189.200 scope global lo:0
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: ens33:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:73:7c:4c brd ff:ff:ff:ff:ff:ff
    inet 192.168.189.129/24 brd 192.168.189.255 scope global ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::165b:9d77:48be:464c/64 scope link
       valid_lft forever preferred_lft forever
    inet6 fe80::b485:96d0:c537:251e/64 scope link tentative dadfailed
       valid_lft forever preferred_lft forever
3: ens37:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:73:7c:56 brd ff:ff:ff:ff:ff:ff
    inet6 fe80::db6f:ae30:c2f3:81c5/64 scope link
       valid_lft forever preferred_lft forever  rs2,
# ip add
1: lo:mtu 65536 qdisc noqueue state UNKNOWN qlen 1
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet 192.168.189.200/32 brd 192.168.189.200 scope global lo:0
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host
       valid_lft forever preferred_lft forever
2: ens33:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:46:b2:9c brd ff:ff:ff:ff:ff:ff
    inet 192.168.189.130/24 brd 192.168.189.255 scope global ens33
       valid_lft forever preferred_lft forever
    inet6 fe80::b485:96d0:c537:251e/64 scope link
       valid_lft forever preferred_lft forever
3: ens37:mtu 1500 qdisc pfifo_fast state UP qlen 1000
    link/ether 00:0c:29:46:b2:a6 brd ff:ff:ff:ff:ff:ff  6 准备工作完成,进行访问vip测试。
  在windows浏览器上进行访问测试
  由于windows有缓存的问题存在,在实验上可能会影响实验结果,所以只能尝试在不同浏览器上进行访问测试
  6.1 在google chrome浏览器上访问vip
http://s1.运维网.com/images/20180524/1527144798685708.png
  转到rs1上
  6.2 在360浏览器上访问vip
http://s1.运维网.com/images/20180524/1527144804844453.png
  转到rs2上
  上面也实现了负载均衡的作用。
  18.12 Keepalived+LVS DR
  Keepalvied加入LVS的原因是:

[*]  如果LVS的分发器(dir)宕机,所有的访问都会被终止,因为全部入口都在dir上。但是在dir上搭建高可用功能的话,可以起到高可用和负载均衡的作用,可以是宕机了的dir起到高可用作用。
[*]  LVS后端的其中一台rs(例如rs2)宕机后,请求最终还是会被dir分发到rs2上,这样的话最终会造成访问失败。但是keepalived可以解决到这种问题,当keepalived检测到rs2出现问题之后,不会将请求发送给rs2,此时LVS的检测功能会被认定rs2不存在,然后dir会继续分发请求到正常的rs上,这样的话能保证业务能正常运作。


[*]  完整架构需要两台服务器(角色为dir)分别安装keepalived软件,目的是实现高可用,但keepalived本身也有负载均衡的功能,所以本次实验可以只安装一台keepalived
[*]  keepalived内置了ipvsadm的功能,所以不需要再安装ipvsadm包,也不用编写和执行那个lvs_dir的脚本
  1 准备工作:
  三台机器分别为:
  dir(安装keepalived)192.168.189.128
  rs1 192.168.189.129
  rs2 192.168.189.130
  vip 192.168.189.200
  2 编辑keepalived配置文件 vim /etc/keepalived/keepalived.conf
  内容请到https://coding.net/u/aminglinux/p/aminglinux-book/git/blob/master/D21Z/lvs_keepalived.conf   获取
vrrp_instance VI_1 {
    #备用服务器上为 BACKUP
    state MASTER
    #绑定vip的网卡为ens33,根据实际情况修改
    interface ens33
    virtual_router_id 51
    #备用服务器上为90
    priority 100
    advert_int 1
    authentication {
      auth_type PASS
      auth_pass aminglinux
    }
    virtual_ipaddress {
      192.168.188.110
    }
}
virtual_server 192.168.188.110 80 {
    #(每隔10秒查询realserver状态)
    delay_loop 10
    #(lvs 算法)
    lb_algo wlc
    #(DR模式)
    lb_kind DR
    #(同一IP的连接60秒内被分配到同一台realserver)
    persistence_timeout 60
    #(用TCP协议检查realserver状态)
    protocol TCP
    real_server 192.168.188.129 80 {
      #(权重)
      weight 100
      TCP_CHECK {
      #(10秒无响应超时)
      connect_timeout 10
      nb_get_retry 3
      delay_before_retry 3
      connect_port 80
      }
    }
    real_server 192.168.188.127 80 {
      weight 100
      TCP_CHECK {
      connect_timeout 10
      nb_get_retry 3
      delay_before_retry 3
      connect_port 80
      }
   }
}  参数解释:
  查看上面带#注释的解释。
  3 需要更改里面的ip信息(修改vip,rs1,rs2的ip地址)
  4 启动keepalived服务
  # systemctl start keepalived
  # ps aux |grep keepalived
  root      17740.00.1 1186081384 ?      Ss   12:01   0:00 /usr/sbin/keepalived -D
  root      17750.00.3 1274723348 ?      S    12:01   0:00 /usr/sbin/keepalived -D
  root      17760.00.2 1273402616 ?      S    12:01   0:00 /usr/sbin/keepalived -D
  root      17870.00.0 112676   984 pts/0    S+   12:01   0:00 grep --color=auto keepalived
  5 执行ipvsadm -C把之前的ipvsadm规则清空掉(根据实际情况操作,此处是因为LVS设置了vip,所以当keepalived也建立vip的时候会有发生冲突的机会,所以需要把lvs的规则清理一遍)
  查看ipvsadm的状态(可以看到rs1,rs2的宕机情况,如果其中一方不在,即表示宕机状态)
# ipvsadm -ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port         Forward Weight ActiveConn InActConn
TCP192.168.189.200:80 wlc persistent 60
-> 192.168.189.129:80         Route   100    0          0         
-> 192.168.189.130:80         Route   100    0          0  6 systemctl restart network 可以把之前的vip清空掉
  7 两台rs上,依然要执行/usr/local/sbin/lvs_rs.sh脚本
  # sh /usr/local/sbin/lvs_rs1.sh
  # sh /usr/local/sbin/lvs_rs2.sh
  8 keepalived有一个比较好的功能,可以在一台rs宕机时,不再把请求转发过去测试
  进行第一次测试,
  rs1与rs2的架构是一样的,
  当把其中一台rs(例如rs2)的与keepalived关联的核心服务(nginx)关闭掉的时候,访问vip的时候会跳转到rs1上。
# systemctl stop nginx.service
# systemctl restart keepalived
# ipvsadm -ln
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port         Forward Weight ActiveConn InActConn
TCP192.168.189.200:80 wlc persistent 60
-> 192.168.189.129:80         Route   100    0          0  

  浏览器访问,跳转到rs1上
http://s1.运维网.com/images/20180524/1527136781493687.png
  进行第二次测试
  rs1与rs2的架构是一样的,
  把rs2的nginx服务恢复正常,把rs1的nginx关掉,
  # systemctl stop nginx
  # ipvsadm -ln
  IP Virtual Server version 1.2.1 (size=4096)
  Prot LocalAddress:Port Scheduler Flags
  -> RemoteAddress:Port         Forward Weight ActiveConn InActConn
  TCP192.168.189.200:80 wlc persistent 60
  -> 192.168.189.130:80         Route   100    0          0
  浏览器访问,跳转到rs2上
http://s1.运维网.com/images/20180524/1527136785811933.png
  9 测试成功,搭建成功。



页: [1]
查看完整版本: 18.11