LVS实战案例(LVS-DR模式多网段案例)

归志宁无五亩园,读书本意在元元。这篇文章主要讲述LVS实战案例:LVS-DR模式多网段案例相关的知识,希望能为你提供帮助。
LVS:Linux Virtual Server,负载调度器,Linux内核集成,是章文嵩(花名 正明)博士主导的开源负载均衡项目。该项目在Linux内核中实现了基于IP的数据请求负载均衡调度方案,用户从外部发起访问,Web请求会发送给LVS调度器,调度器根据自己预设的算法决定将该请求发送给后端的某台Web服务器,服务器处理好请求将结果反馈给用户。LVS有多种工作模式:lvs-natlvs-drlvs-tun。

?本文在多网段内实现lvs-dr模式,可以配合网络设备的调测,将LVS规划得层次更清晰。
【LVS实战案例(LVS-DR模式多网段案例)】 本次实验为了验证测试出效果采用了rr调度算法,实际生产中根据实际情况优选算法。
?
1.架构和主机
整体思路:client发起请求,第一阶段到达路由器eth1;第二阶段从路由器eth0到达LVS;第三阶段LVS将请求按照设定的算法调度到后端的RS上;第四阶段RS1直接将回应的数据包通过lo-VIP发送给路由器eth0;第五阶段返回的回应数据包从路由器eth1传输到client,完成整个的数据传输过程。
这个过程中是通过修改各RS内核参数,来限制arp响应和通告,避免VIP地址冲突问题。

# 五台主机
12台RS服务器 :
主机名:RS1-IP18
CentOS 8.4
eth0:RIP:192.168.250.18/24GW:192.168.250.68
lo:VIP:10.0.0.111/32
httpd web服务页面内容 RS1-IP18 IP:192.168.250.18

主机名:RS2-IP28
CentOS 8.4
eth0:RIP:192.168.250.28/24GW:192.168.250.68
lo:VIP:10.0.0.111/32
httpd web服务页面内容 RS2-IP28 IP:192.168.250.28

21台LVS服务器 :
主机名: LVS-IP08
CentOS 8.4
lo:VIP:10.0.0.111/32
eth0:DIP:192.168.250.8/24GW:192.168.250.68
ipvsadm

31台充当路由器的主机
主机名: Router-IP68
eth0 IP:192.168.250.68/24eth0:1 IP:10.0.0.68/24
eth1 IP:172.16.0.68/24

41台client主机 :
主机名: Client-IP48
CentOS 8.4
eth0 IP:172.16.0.48/24GW:172.16.0.68

2.基础环境及网络配置
任务及过程:按照RS两台主机、client终端、充当路由器角色的主机、LVS主机的顺序完成环境及网络配置。
2.1两台RS主机2.1.1第一台RS1 IP192.168.250.18配置
#### 第一台RS1 IP192.168.250.18配置
# 验证防火墙、Selinux关闭;修改主机名、同步时间等操作系统优化
[root@CentOS84 ]#hostnamectl set-hostname RS1-IP18
[root@CentOS84 ]#exit
[root@RS1-IP18 ]#systemctl enable--now chronyd.service

# 安装Apache httpd,并定义和修改主页,让后面测试更直观;可以用下面的命令将主机名和IP地址同时写在 index.html 文件中,分成了两行
[root@RS1-IP18 ]#yum -y install httpd; hostname > /var/www/html/index.html; hostname -I > > /var/www/html/index.html; systemctlenable --now httpd

# VCSA下创建得虚拟机会自动生成一个虚拟桥接网卡 virbr0,用下面命令临时删除掉
[root@RS1-IP18 ]#nmcli con del virbr0

# 修改网卡得配置,符合网络规划
[root@RS1-IP18 ]#vim /etc/sysconfig/network-scripts/ifcfg-Profile_1
TYPE=Ethernet
DEVICE=eth0
NAME="eth0"
IPADDR=192.168.250.18
PREFIX=24
GATEWAY=192.168.250.68
DEFROUTE=yes
ONBOOT=yes

# 让网卡配置生效
[root@RS1-IP18 ]#nmcli con reload
[root@RS1-IP18 ]#nmcli con up eth0

[root@RS1-IP18 ]#ip add
1: lo: < LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
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

2: eth0: < BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 00:50:56:a3:e8:6b brd ff:ff:ff:ff:ff:ff
inet 192.168.250.18/24 brd 192.168.250.255 scope global noprefixroute eth0
valid_lft forever preferred_lft forever

[root@RS1-IP18 ]#route -n
Kernel IP routing table
DestinationGatewayGenmaskFlags Metric RefUse Iface
0.0.0.0192.168.250.680.0.0.0UG10000 eth0
192.168.250.00.0.0.0255.255.255.0U10000 eth0
[root@RS1-IP18 ]#

[root@RS1-IP18 ]#curl 192.168.250.18
RS1-IP18
192.168.250.18

2.1.1第二台RS2 IP192.168.250.28配置
#### 第二台RS2 IP192.168.250.28配置
# 验证防火墙、Selinux关闭;修改主机名、同步时间等操作系统优化
[root@CentOS84 ]#hostnamectl set-hostname RS2-IP28
[root@CentOS84 ]#exit
[root@RS2-IP28 ]#systemctl enable --nowchronyd.service

# 安装Apache httpd,并定义和修改主页
[root@RS2-IP28 ]#yum -y install httpd; hostname > /var/www/html/index.html; hostname -I > > /var/www/html/index.html; systemctlenable --now httpd

# VCSA下创建得虚拟机会自动生成一个虚拟桥接网卡 virbr0,用下面命令临时删除掉
[root@RS1-IP28 ]#nmcli con del virbr0

# 按照规划修改网卡配置
[root@RS2-IP28 ]#vim /etc/sysconfig/network-scripts/ifcfg-Profile_1
[root@RS2-IP28 ]#cat /etc/sysconfig/network-scripts/ifcfg-Profile_1
TYPE=Ethernet
DEVICE=eth0
NAME="eth0"
IPADDR=192.168.250.28
PREFIX=24
GATEWAY=192.168.250.68
DEFROUTE=yes
ONBOOT=yes

# 使得网卡配置生效
[root@RS2-IP28 ]#nmcli con reload
[root@RS2-IP28 ]#nmcli con up eth0

# 验证网络信息
[root@RS2-IP28 ]#route -n
Kernel IP routing table
DestinationGatewayGenmaskFlags Metric RefUse Iface
0.0.0.0192.168.250.680.0.0.0UG10000 eth0
192.168.250.00.0.0.0255.255.255.0U10000 eth0
[root@RS2-IP28 ]#

[root@RS2-IP28 ]#ip add
1: lo: < LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
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

2: eth0: < BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 00:50:56:a3:e2:bf brd ff:ff:ff:ff:ff:ff
inet 192.168.250.28/24 brd 192.168.250.255 scope global noprefixroute eth0
valid_lft forever preferred_lft forever

[root@RS2-IP28 ]#curl 192.168.250.28
RS2-IP28 IP:192.168.250.28
[root@RS2-IP28 ]#

[root@RS2-IP28 ]#curl 192.168.250.28
RS2-IP28
192.168.250.28

2.2测试用client 主机
# 验证防火墙、Selinux关闭;修改主机名、同步时间等操作系统优化

[root@CentOS84 ]#hostnamectl set-hostname Client-IP48
[root@CentOS84 ]#exit
[root@Client-IP48 ]#systemctl enable --nowchronyd.service

# 修改网卡配置
[root@Client-IP48 ]#vim /etc/sysconfig/network-scripts/ifcfg-Profile_1
TYPE=Ethernet
DEVICE=eth0
NAME="eth0"
IPADDR=172.16.0.48
PREFIX=24
GATEWAY=172.16.0.68
DEFROUTE=yes
ONBOOT=yes
# 使得网卡配置生效
[root@Client-IP48 ]#nmcli connection reload
[root@Client-IP48 ]#nmcli connection up eth0

# 查看网卡地址和路由信息
[root@Client-IP48 ]#ip add
1: lo: < LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
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

2: eth0: < BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 00:50:56:a3:48:a4 brd ff:ff:ff:ff:ff:ff
inet 172.16.0.48/24 brd 172.16.0.255 scope global noprefixroute eth0
valid_lft forever preferred_lft forever

[root@Client-IP48 ]#ip route
default via 172.16.0.68 dev eth0 proto static metric 100
172.16.0.0/24 dev eth0 proto kernel scope link src 172.16.0.48 metric 100


#### 路由角色的主机配置好后测试跨路由通信,确保在部署IPVS配置前网络是互通的
# 测试到路由器三个IP地址的通信,确保能PING通
[root@Client-IP48 ]#ping 172.16.0.68
PING 172.16.0.68 (172.16.0.68) 56(84) bytes of data.
64 bytes from 172.16.0.68: icmp_seq=1 ttl=64 time=0.425 ms
64 bytes from 172.16.0.68: icmp_seq=2 ttl=64 time=0.442 ms
64 bytes from 172.16.0.68: icmp_seq=3 ttl=64 time=0.447 ms
^C
--- 172.16.0.68 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2079ms
rtt min/avg/max/mdev = 0.425/0.438/0.447/0.009 ms
[root@Client-IP48 ]#

[root@Client-IP48 ]#ping 10.0.0.68
PING 10.0.0.68 (10.0.0.68) 56(84) bytes of data.
64 bytes from 10.0.0.68: icmp_seq=1 ttl=64 time=0.498 ms
64 bytes from 10.0.0.68: icmp_seq=2 ttl=64 time=0.392 ms
64 bytes from 10.0.0.68: icmp_seq=3 ttl=64 time=0.402 ms
^C
--- 10.0.0.68 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2026ms
rtt min/avg/max/mdev = 0.392/0.430/0.498/0.053 ms
[root@Client-IP48 ]#

[root@Client-IP48 ]#ping 192.168.250.68
PING 192.168.250.68 (192.168.250.68) 56(84) bytes of data.
64 bytes from 192.168.250.68: icmp_seq=1 ttl=64 time

    推荐阅读