配置方案
- 
- [1. 在主备节点上安装软件](#1. 在主备节点上安装软件)
 - [2. 编写配置文件](#2. 编写配置文件)
 - [3. 启动keepalived服务](#3. 启动keepalived服务)
 
 - 
- [1. 安装并启动http服务](#1. 安装并启动http服务)
 - [2. 编写主页面](#2. 编写主页面)
 - 3.配置虚拟地址
 - [4. 配置ARP](#4. 配置ARP)
 
 - 
服务器IP:
- 主负载均衡服务器 master 192.168.152.71
 - 备负载均衡服务器 backup 192.168.152.72
 - web服务器1 web1 192.168.152.73
 - web服务器2 web2 192.168.152.74
 - 虚拟IP VIP 192.168.152.100
 
 
一、配置主备节点
1. 在主备节点上安装软件
            
            
              bash
              
              
            
          
          yum install -y keepalived ipvsadm
        2. 编写配置文件
master.ip 和 backup.ip 都要配置,把原本的内容清空
            
            
              bash
              
              
            
          
          vim /etc/keepalived/keepalived.conf
        写如下内容: 确保主备节点的 router_id state priority 的值不一样
            
            
              bash
              
              
            
          
          ! Configuration File for keepalived
global_defs {
    router_id 1  # 唯一标识本节点的路由器ID,主备节点的ID必须不同
}
vrrp_instance VI_1 {
    state MASTER                # 主节点的状态为MASTER,备节点的状态为BACKUP
    interface ens33             # 用于主备节点之间通信的网卡名称
    virtual_router_id 51        # 虚拟路由器ID,主备节点必须一致
    priority 100                # 节点优先级,数字越大优先级越高
    advert_int 1                # VRRP 广播间隔时间,单位为秒
    authentication {
        auth_type PASS         # 认证方式为PASS
        auth_pass 123456       # 认证密码,主备节点上的密码必须一致,密码最大8位
    }
    virtual_ipaddress {
        192.168.152.100/24    # 配置的虚拟IP地址及子网掩码,VIP地址
    }
}
virtual_server 192.168.152.100 80 {  # 定义虚拟服务器,端口80
    delay_loop 3                # 健康检查的间隔时间,每3秒检查一次后端服务器状态
    lb_algo rr                  # 负载均衡算法,使用轮询(rr)方式
    lb_kind DR                  # LVS 集群模式,使用Direct Routing(DR)模式
    protocol TCP                # 使用TCP协议进行负载均衡
    real_server 192.168.152.73 80 {  # web1服务器IP地址,端口80
        weight 1                # 服务器权重,权重相同表示流量均等分配
        TCP_CHECK {
            connect_timeout 3  # TCP健康检查的连接超时时间,3秒内成功连接视为健康
        }
    }
    real_server 192.168.152.74 80 {  # web2服务器IP地址,端口80
        weight 1                # 服务器权重
        TCP_CHECK {
            connect_timeout 3  # TCP健康检查的连接超时时间
        }
    }
}
        3. 启动keepalived服务
            
            
              bash
              
              
            
          
          systemctl start keepalived && systemctl enable keeplavied
        二、配置web服务器
下面的内容 web1 和 web2 都要配置
1. 安装并启动http服务
这里用apache测试,不重要其它http服务也无所谓
            
            
              bash
              
              
            
          
          yum install -y httpd && systemctl start httpd && systemctl enable httpd
        2. 编写主页面
web1:
            
            
              bash
              
              
            
          
          echo web1 > /var/www/html/index.html
        web2:
            
            
              bash
              
              
            
          
          echo web2 > /var/www/html/index.html
        这样写是为了在最后访问时效果更明显,方便区分
3.配置虚拟地址
复制 ifcfg-lo 网卡配置文件,并改名为 ifcfg-lo:0
            
            
              bash
              
              
            
          
          cp /etc/sysconfig/network-scripts/{ifcfg-lo,ifcfg-lo:0}
        更改 vim /etc/sysconfig/network-scripts/ifcfg-lo:0 文件的内容如下
            
            
              bash
              
              
            
          
          DEVICE=lo:0
IPADDR=192.168.152.100   #对外提供服务的虚拟地址
NETMASK=255.255.255.255
ONBOOT=yes
        4. 配置ARP
            
            
              bash
              
              
            
          
          # 在所有网络接口上设置 ARP 请求的响应行为
net.ipv4.conf.all.arp_ignore = 1
# 设置 ARP 忽略规则为 1:只响应目标地址与本接口地址匹配的 ARP 请求。这有助于避免错误的 ARP 响应。
net.ipv4.conf.all.arp_announce = 2
# 设置 ARP 宣告规则为 2:只在接口上声明 IP 地址,当 IP 地址只在该接口上有效时。这有助于避免将 IP 地址错误地声明在多个接口上。
# 在默认的网络接口上设置 ARP 请求的响应行为
net.ipv4.conf.default.arp_ignore = 1
# 设置默认网络接口的 ARP 忽略规则为 1:只响应目标地址与本接口地址匹配的 ARP 请求。这确保新添加的接口也遵循相同的 ARP 忽略规则。
net.ipv4.conf.default.arp_announce = 2
# 设置默认网络接口的 ARP 宣告规则为 2:只在接口上声明 IP 地址,当 IP 地址只在该接口上有效时。这确保新添加的接口也遵循相同的 ARP 宣告规则。
# 在回环接口 (lo) 上设置 ARP 请求的响应行为
net.ipv4.conf.lo.arp_ignore = 1
# 设置回环接口的 ARP 忽略规则为 1:回环接口只响应针对本接口的 ARP 请求,避免干扰其他接口的 ARP 行为。
net.ipv4.conf.lo.arp_announce = 2
# 设置回环接口的 ARP 宣告规则为 2:回环接口只在其上声明 IP 地址,这防止了回环接口在其他接口上错误地声明 IP 地址。
        三、测试
在浏览器输入虚拟IP地址 192.168.152.100
刷新观察变化,如果一直没有变化可能是浏览器缓存,可以用下面命令查看,在 master 上执行
            
            
              bash
              
              
            
          
          ipvsadm -Lnc
        结果如下:
            
            
              bash
              
              
            
          
          IPVS connection entries
pro expire state       source             virtual            destination
TCP 01:37  FIN_WAIT    192.168.152.1:55317 192.168.152.100:80 192.168.152.74:80
TCP 15:02  ESTABLISHED 192.168.152.1:55428 192.168.152.100:80 192.168.152.73:80
看最后一列IP地址,可以看到已经分配到两个web服务器上
        把 master 主机的 keepalived 服务关闭,观察 backup 主机
在 backup 主机输入下面命令,看虚拟IP是否存在,并刷新网页看是否可用
            
            
              bash
              
              
            
          
          ip a