zoukankan      html  css  js  c++  java
  • Centos7+LVS-DR+Apache负载均衡web实验

    一、简介

      1、理论已经在上一篇博客简述,不了解得可以看看

        https://www.cnblogs.com/zhangxingeng/p/10497279.html 

      2、LVS-DR优缺点复习     

        关于这种模式:

          1)确保前端路由器将目标ip为vip的请求报文发往director

            a、在前端网关做静态绑定;

            b、在RS上使用arptables;

            c、在RS上修改内核参数以限制arp通告即应答级别;

              arp_announce

              arp_ignore

          2)、RS的RIP可以使用私网或公网地址;

          3)、RS跟director在同一物理网络;

          4)、请求报文经由director,响应报文直接发往client;

          5)、此模式不支持端口映射;

          6)、RS支持大多数的OS;

          7)、RIP的网关不能指向DIP,以确保响应报文不经由director;

          

         缺点:LVS调度器及应用服务器在同一个网段中,因此不能实现集群的跨网段应用。

         优点:直接路由转发,通过修改请求报文的目标mac地址进行转发,效率提升明显

      3、实验拓扑

     

        实验说明:测试环境为虚拟机,准备三台即可,这里是四台外加本机物理机

    节点 ip 应用 ip2 备注
    web1 192.168.13.11(DIP) director VIP:ens37:0,192.168.13.100  
    web2 192.168.13.12(RIP) rs VIP:Lo:0,192.168.13.100  
    web3 192.168.13.13(RIP) rs VIP:Lo:0,192.168.13.100  
    web4 192.168.13.14 client   curl
    本地物理机测试 172网段 client   web访问

        

    二、开始部署

      1、网络配置

       修改虚拟机网卡rip、vip、dip都在同一个网段,这里使用仅主机模式

        配置网卡基础参数这里就不演示,配置静态,网关指向仅主机虚拟网卡网关即可

       director一块网卡即可,后续配置添加vip使用别名即可,别着急,在后面具体配置上

        

    1 [root@web1 ~]#  ifconfig 
    2 ens37: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
    3         inet 192.168.13.11  netmask 255.255.255.0  broadcast 192.168.13.255
    4         inet6 fe80::20c:29ff:fe1c:8b43  prefixlen 64  scopeid 0x20<link>
    5         ether 00:0c:29:1c:8b:43  txqueuelen 1000  (Ethernet)
    6         RX packets 271095  bytes 48234818 (46.0 MiB)
    7         RX errors 0  dropped 0  overruns 0  frame 0
    8         TX packets 129716  bytes 9264277 (8.8 MiB)
    9         TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

       

       rs也是一块网卡,后续vip配置在lo:0上即可但是需要先修改arp_ignore,arp_announce才能添加lo:0

       

    1 [root@web2 ~]# ifconfig
    2 ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
    3         inet 192.168.13.12  netmask 255.255.255.0  broadcast 192.168.13.255
    4         inet6 fe80::3409:e73d:1ef:2e1  prefixlen 64  scopeid 0x20<link>
    5         ether 00:0c:29:75:de:46  txqueuelen 1000  (Ethernet)
    6         RX packets 291171  bytes 43500727 (41.4 MiB)
    7         RX errors 0  dropped 0  overruns 0  frame 0
    8         TX packets 84267  bytes 12274101 (11.7 MiB)
    9         TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    [root@web3 ~]# ifconfig
    ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            inet 192.168.13.13  netmask 255.255.255.0  broadcast 192.168.13.255
            inet6 fe80::3409:e73d:1ef:2e1  prefixlen 64  scopeid 0x20<link>
            inet6 fe80::9416:80e8:f210:1e24  prefixlen 64  scopeid 0x20<link>
            ether 00:0c:29:79:23:62  txqueuelen 1000  (Ethernet)
            RX packets 281305  bytes 43019942 (41.0 MiB)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 88839  bytes 12307738 (11.7 MiB)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

     

      2、关闭防火墙

        

    1       systemctl stop firewalld
    2 
    3       systemctl disable firewalld
    4 
    5       sed -i '/SELINUX/s/enforcing/disabled/' /etc/selinux/config 

      3、安装软件

    1       11上安装ipvsadm     
    2         yum install ipvsadm -y 
    3       12、13安装httpd
    4         yum install httpd -y
      

      4、配置web

         注意:arp_ignore 改为1的意义是,响应报文,请求报文从哪个地址进来的,就只能这个接口地址响应

           arp_announce 改为2的意义是,通知,不通告不同网段

     1 #修改web页面
     2       web2
     3  
     4          echo "welcom to web2" >/var/www/html/index.html
     5  
     6       web3
     7         echo "welcom to web3" >/var/www/html/index.html
     8 #启动与开机自启
     9          systemctl restart httpd
    10          systemctl enable httpd
    11 #修改内核参数,两台rs都修改
    12   echo 1 > /porc/sys/net/ipv4/conf/all/arp_ignore
    13   echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore
    14   echo 1 > /proc/sys/net/ipv4/conf/ens33/arp_ignore
    15   echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce 
    16   echo 2 > /proc/sys/net/ipv4/conf/ens33/arp_announce 
      #添加vip
      ifconfig lo:0 192.168.13.100 broadcast 192.168.13.100 netmask 255.255.255.255 up
    17 #添加默认路由,两台rs都修改,

    18 route add -host 192.168.13.100 dev lo:0

    19
      #ping 192.168.13.100 
    20

    ping 192.168.13.100

    21
    #物理机查看mac地址没有变化,说明rs没有响应ok ,11和100的地址保持一致就是对的
       物理机是windows10 cmd 命令行 arp -a 查看mac表
    22 arp -a
    2
    3 接口: 192.168.13.1 --- 0x16

    24 Internet 地址 物理地址 类型

    25 192.168.13.11 00-0c-29-1c-8b-43 动态

    26 192.168.13.12 00-0c-29-75-de-46 动态

    27 192.168.13.13 00-0c-29-79-23-62 动态

    28 192.168.13.14 00-0c-29-0f-ea-b4 动态

    29 192.168.13.100 00-0c-29-1c-8b-43 动态

        检查网络信息,web2举例,web3差不多就不贴上来了

     1 [root@web2 ~]# ifconfig
     2 ens33: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
     3         inet 192.168.13.12  netmask 255.255.255.0  broadcast 192.168.13.255
     4         inet6 fe80::3409:e73d:1ef:2e1  prefixlen 64  scopeid 0x20<link>
     5         ether 00:0c:29:75:de:46  txqueuelen 1000  (Ethernet)
     6         RX packets 291171  bytes 43500727 (41.4 MiB)
     7         RX errors 0  dropped 0  overruns 0  frame 0
     8         TX packets 84267  bytes 12274101 (11.7 MiB)
     9         TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    10 
    11 lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
    12         inet 127.0.0.1  netmask 255.0.0.0
    13         inet6 ::1  prefixlen 128  scopeid 0x10<host>
    14         loop  txqueuelen 1  (Local Loopback)
    15         RX packets 1181  bytes 99767 (97.4 KiB)
    16         RX errors 0  dropped 0  overruns 0  frame 0
    17         TX packets 1181  bytes 99767 (97.4 KiB)
    18         TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    19 
    20 lo:0: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
    21         inet 192.168.13.100  netmask 255.255.255.255
    22         loop  txqueuelen 1  (Local Loopback)
    23 
    24 virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
    25         inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
    26         ether 52:54:00:23:a5:7c  txqueuelen 1000  (Ethernet)
    27         RX packets 0  bytes 0 (0.0 B)
    28         RX errors 0  dropped 0  overruns 0  frame 0
    29         TX packets 0  bytes 0 (0.0 B)
    30         TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    31 
    32 [root@web2 ~]# 

       

      5、配置director

         lvs-dr模式不需要开启地址转发,ip_forward功能,因为director发给rs的数据包是修改过的包,不是原包,不经过ip_forward转发,而是经过修改后的mac根据l路由决策直接路由到rip

     1 #ens33是另外一块网卡down掉,配置网卡别名,添加vip
     2  ifconfig ens33 down
     3  ifconfig ens37:0 192.168.13.100/24 broadcast 192.168.13.100 up
     4 #配置ipvsadm
     5 ipvsadm -C 清空
     6 #添加规则
     7  ipvsadm -A -t 192.168.13.100:80 -s rr
     8  ipvsadm -a -t 192.168.13.100:80 -r 192.168.13.12 -g
     9  ipvsadm -a -t 192.168.13.100:80 -r 192.168.13.13 -g
    10 #查看规则
    11 [root@web1 zhangxingeng]# ipvsadm -ln
    12 IP Virtual Server version 1.2.1 (size=4096)
    13 Prot LocalAddress:Port Scheduler Flags
    14   -> RemoteAddress:Port           Forward Weight ActiveConn InActConn
    15 TCP  192.168.13.100:80 rr
    16   -> 192.168.13.12:80             Route   1      0          0         
    17   -> 192.168.13.13:80             Route   1      0          0         

        检查网络信息

        

    [root@web1 ~]#  ifconfig 
    ens37: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            inet 192.168.13.11  netmask 255.255.255.0  broadcast 192.168.13.255
            inet6 fe80::20c:29ff:fe1c:8b43  prefixlen 64  scopeid 0x20<link>
            ether 00:0c:29:1c:8b:43  txqueuelen 1000  (Ethernet)
            RX packets 271095  bytes 48234818 (46.0 MiB)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 129716  bytes 9264277 (8.8 MiB)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    
    ens37:0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
            inet 192.168.13.100  netmask 255.255.255.255  broadcast 192.168.13.100
            ether 00:0c:29:1c:8b:43  txqueuelen 1000  (Ethernet)
    
    lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
            inet 127.0.0.1  netmask 255.0.0.0
            inet6 ::1  prefixlen 128  scopeid 0x10<host>
            loop  txqueuelen 1  (Local Loopback)
            RX packets 123187  bytes 11609729 (11.0 MiB)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 123187  bytes 11609729 (11.0 MiB)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    
    virbr0: flags=4099<UP,BROADCAST,MULTICAST>  mtu 1500
            inet 192.168.122.1  netmask 255.255.255.0  broadcast 192.168.122.255
            ether 52:54:00:23:a5:7c  txqueuelen 1000  (Ethernet)
            RX packets 0  bytes 0 (0.0 B)
            RX errors 0  dropped 0  overruns 0  frame 0
            TX packets 0  bytes 0 (0.0 B)
            TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0
    
    [root@web1 ~]# 

      6、测试结果

     

     1 [root@web4 ~]# curl 192.168.13.100
     2 welcom to web3
     3 [root@web4 ~]# curl 192.168.13.100
     4 welcom to web2
     5 [root@web4 ~]# curl 192.168.13.100
     6 welcom to web3
     7 [root@web4 ~]# curl 192.168.13.100
     8 welcom to web2
     9 [root@web4 ~]# curl 192.168.13.100
    10 welcom to web3
    11 [root@web4 ~]# curl 192.168.13.100
    12 welcom to web2
    13 [root@web4 ~]# curl 192.168.13.100
    14 welcom to web3
    #统计信息
    [root@web1 ~]# ipvsadm -ln --stats IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Conns InPkts OutPkts InBytes OutBytes -> RemoteAddress:Port TCP 192.168.13.100:80 46 500 0 93970 0 -> 192.168.13.12:80 23 250 0 47616 0 -> 192.168.13.13:80 23 250 0 46354 0 [root@web1 ~]#
     #连接条目
    1
    [root@web1 ~]# ipvsadm -lnc 2 IPVS connection entries 3 pro expire state source virtual destination 4 TCP 01:53 FIN_WAIT 192.168.13.163:48482 192.168.13.100:80 192.168.13.12:80 5 TCP 01:54 FIN_WAIT 192.168.13.163:48488 192.168.13.100:80 192.168.13.13:80 6 TCP 01:53 FIN_WAIT 192.168.13.163:48480 192.168.13.100:80 192.168.13.13:80 7 TCP 14:56 ESTABLISHED 192.168.13.1:59343 192.168.13.100:80 192.168.13.13:80 8 TCP 01:52 FIN_WAIT 192.168.13.163:48478 192.168.13.100:80 192.168.13.12:80 9 TCP 01:54 FIN_WAIT 192.168.13.163:48490 192.168.13.100:80 192.168.13.12:80 10 TCP 01:53 FIN_WAIT 192.168.13.163:48484 192.168.13.100:80 192.168.13.13:80 11 TCP 01:53 FIN_WAIT 192.168.13.163:48486 192.168.13.100:80 192.168.13.12:80 12 TCP 15:01 ESTABLISHED 192.168.13.1:59344 192.168.13.100:80 192.168.13.12:80

     

    转载请注明出处:https://www.cnblogs.com/zhangxingeng/p/10573695.html 

  • 相关阅读:
    移动端阻止事件冒泡需要注意!
    JavaScript闭包
    JS原型与原型链终极讲解
    逐行分析jQuery源码
    jQuery源码分析-03构造jQuery对象-源码结构和核心函数
    screenX clientX pageX的区别
    JSON.stringify 语法实例讲解
    pipenv 简要指南
    webpy简单使用
    初识Dash -- 构建一个人人都能够轻松上手的界面,操控数据和可视化
  • 原文地址:https://www.cnblogs.com/zhangxingeng/p/10573695.html
Copyright © 2011-2022 走看看