本实验通过配置 LVS-NAT 负载均衡器和 NFS 共享存储,实现多台 Web 服务器(Real Servers)的负载均衡,并确保所有服务器能访问同一共享文件。
- 实验步骤
LVS 虚拟服务器
root@localhost \~\]# modprobe ip_vs //加载 ip_vs 模块 \[root@localhost \~\]# cat /proc/net/ip_vs //查看 ip_vs 版本信息 IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -\> RemoteAddress:Port Forward Weight ActiveConn InActCon 使用 ipvsadm 管理工具 yum -y install ipvsadm ipvsadm -v ipvsadm v1.27 2008/5/15 (compiled with popt and IPVS v1.2.1) 创建虚拟服务器 若群集的 VIP 地址为 172.16.16.172,针对 TCP 80 端口提供负载分流服务,使用的调 度算法为轮询,则对应的 ipvsadm 命令操作如下所示。对于负载均衡调度器来说,VIP 必须是本机实际已启用的 IP 地址 ipvsadm -A -t 172.16.16.172:80 -s rr 选项-A 表示添加虚拟服务器,-t 用来指定 VIP 地址及 TCP 端口,-s 用来 指定负载调度算法------轮询(rr)、加权轮询(wrr)、最少连接(lc)、加权最少连接(wlc) 添加服务器节点 为虚拟服务器 172.16.16.172 添加四个服务器节点,IP 地址依次为 192.168.7.21~24, 对应的 ipvsadm 命令操作如下所示。若希望使用保持连接,还应添加"-p 60"选项,其中 60 为保持时间(单位为 s)。 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.1:80 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.2:80 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.3:80 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.4:80 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.5:80 -m -w 1 查看群集节点状态 结合选项-l 可以列表查看 LVS 虚拟服务器,可以指定只查看某一个 VIP 地址(默认为 查看所有),结合选项-n 将以数字形式显示地址、端口等信息。 \[root@localhost \~\]# ipvsadm -ln  删除服务器节点 需要从服务器池中删除某一个节点时,使用选项-d。执行删除操作必须指定目标对象, 包括节点地址、虚拟 IP 地址。例如,以下操作将会删除 LVS 群集 172.16.16.172 中的节点 192.168.7.24。 \[root@localhost \~\]# ipvsadm -d -r 192.168.122.5 -t 10.1.1.3:80 保存负载分配策略 使用导出/导入工具 ipvsadm-save/ipvsadm-restore 可以保存、恢复 LVS 策略。当然也 可以快速清除、重建负载分配策略。 \[root@localhost \~\]# ipvsadm-save \> /etc/sysconfig/ipvsadm //保存策略 \[root@localhost \~\]# cat /etc/sysconfig/ipvsadm //确认保存结果  \[root@localhost \~\]# systemctl stop ipvsadm //停止服务(清除策略) \[root@localhost \~\]# systemctl start ipvsadm //启动服务(重建规则 安装 nfs-utils、rpcbind 软件包 yum -y install nfs-utils rpcbind \[root@localhost \~\]# systemctl enable nfs \[root@localhost \~\]# systemctl enable rpcbind 设置共享目录 mkdir -p /opt/wwwroot \[root@localhost \~\]# vi /etc/exports  启动FNS服务 systemctl start rpcbind Systemctl start nfs Netstat -anpt \|grep rpc  查看本机发布的 NFS 共享目录 \[root@localhost \~\]# showmount -e 安装 rpcbind 软件包,并启动 rpcbind 服务 yum -y install rpcbind nfs-utils \[root@localhost \~\]# systemctl enable rpcbind \[root@localhost \~\]# systemctl start rpcbind 查看共享目录 showmount -e 192.168.122.1  手动挂载 NFS 共享目录 mount 192.168.7.250:/opt/wwwroot /var/www/html \[root@localhost \~\]# tail -1 /etc/mtab  vi /var/www/html/index.html //在客户机创建测试文 Fstab 自动挂载设置 \[root@localhost \~\]# vi /etc/fstab ...... //省略部分信息 192.168.122.1:/opt/wwwroot /var/www/html nfs defaults,_netdev 0 0 配置负载调度器 (1)开启路由转发规则。 \[root@localhost \~\]# vi /etc/sysctl.conf ...... //省略部分信息 net.ipv4.ip_forward = 1 \[root@localhost \~\]# sysctl -p net.ipv4.ip_forward = 1  (2)配置负载分配策略。 \[root@localhost \~\]# ipvsadm -C //清除原有策略 \[root@localhost \~\]# ipvsadm -A -t 10.1.1.3:80 -s rr \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.1 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.2 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.3 -m -w 1 \[root@localhost \~\]# ipvsadm -a -t 10.1.1.3:80 -r 192.168.122.4 -m -w 1 \[root@localhost \~\]# ipvsadm --save //保存策略  \[root@localhost \~\]# systemctl enable ipvsadm Created symlink from /etc/systemd/system/multi-user.target.wants/ipvsadm.service to /usr/lib/systemd/system/ipvsadm.service. 3.配置节点服务器 所有的节点服务器均使用相同的配置,包括 httpd 服务端口、网站文档内容。实际上各 节点的网站文档可存放在共享存储设备中,从而免去同步的过程。但在案例调试阶段可以为 各节点采用不同的网页,以便测试负载均衡效果。 注意:节点服务器的网关必须指向 LVS 调度器。 (1)安装 httpd,创建测试网页。 \[root@localhost \~\]# yum -y install httpd \[root@localhost \~\]# mount 192.168.122.1:/opt/wwwroot /var/www/html //实验时可在不同节点配置不同网页内容测试 LVS,最后在使用 NFS 共享存储统一页面 \[root@localhost \~\]# vi /var/www/html/index.html \