LVS-NAT模式负载均衡的实现

简介:

LVS-NAT架构图解:

  wKioL1SjlZXDz2GRAAJ-1QpO1e4029.jpg                         

 

一.名词解释:

DSDirector Server,前端的LVS Server

RSReal Server;后端的WebServer

VIP:外网, 172.16.31.50

DIP:内网,192.168.31.254

RS1RIP 192.168.31.1

RS2RIP 192.168.31.2



前端是一个Director Server,有两个网卡,一个是公网(面向互联网);一个是连接各RS

外部网络是桥接网卡,内部网络是内部网络网卡连接的;

后端是Real Server,尽可能使用私有地址,网关应指向DIP,将RS做成web服务器

 

二.LVS-NAT模型实现负载均衡的工作方式,

   NAT模型其实就是通过网络地址转换来实现负载均衡的,它的工作方式几乎跟DNAT一模一样的,目前的DNAT只能转发到一个目标地址,早期的DNAT是可以将请求转发到多个目标的,LVS出现之后就将此功能从DNAT种去掉了,下面来说说NAT模型的工作方式或者说NAT模型是怎么实现负载均衡的,根据上图,

1.客户端请求VIP(也可以说是CIP请求VIP);

2.Director Server 收到用户的请求后,发现源地址为CIP请求的目标地址为VIP,那么DorectorServer会认为用户请求的是一个集群服务,那么Director Server 会根据此前设定好的调度算法将用户请求负载给某台Real Server ,假如说此时Director Server 根据调度算法的结果会将请求分摊到Real Server 1上去,那么Director Server 会将用户的请求报文中的目标地址,从原来的VIP改为Real Server 1IP,然后再转发给Real Server 1;

3.此时Real Server 1收到一个源地址为CIP目标地址为自己的请求,那么Real Server1处理好请求后会将一个源地址为自己目标地址为CIP的数据包通过Director Server 发出去;

4.Driector Server收到一个源地址为RealServer 1 IP 目标地址为CIP的数据包,此时Driector Server 会将源地址修改为VIP,然后再将数据包发送给用户;

 

三.LVS用户空间工具ipvsadm的使用方法

    其实LVS的本身跟iptables很相似,而且连命令的使用格式都很相似,其实LVS是根据iptables的框架开发的,那么LVS的本身分成了两个部分,第一部分是工作在内核空间的一个IPVS的模块,其实LVS的功能都是IPVS模块实现的;第二部分是工作在用户空间的一个用来定义集群服务的一个工具ipvsadm, 这个工具的主要作用是将管理员定义的集群服务列表传送给工作在内核空间中的IPVS模块,下面来简单的介绍下ipvsadm命令的用法

 

1.定义集群服务类的

#ipvsadm

-A 添加一个集群服务

-D 删除一个集群服务

-E 修改一个集群服务

    -t VIP:端口   定义集群服务的类型为TCP的某个端口

    -u VIP:端口   定义集群服务的类型为UDP的某个端口

    -f 防火墙标记  定义集群服务的类型为防火墙标记

          -s 调度算法  指定集群服务的调度算法


2.定义集群节点类的

#ipvsadm

-a 添加一个节点到集群服务

-d 从集群服务中删除一个节点

-e 修改集群服务器中的节点

-r 节点IP:端口   定义节点的IP及类型

-m   定义为NAT模型

-g   定义为DR模型

-i   定义为TUN模型

-w 权重   定义服务器的权重

-p --persistent [timeout] 持久稳固的服务。这个选项的意思是来自同一个客
户的多次请求,将被同一台真实的服务器处理。timeout 的默认值为300 秒。      


3.其他

#ipvsadm

-L 查看

   -n --numeric       输出IP 地址和端口的数字形式

   -c --connection   显示LVS 目前的连接 如:ipvsadm -L -c

  --stats          显示统计信息

-C 清空所有规则

-S 保存规则

-R 恢复规则

四.配置IP地址:

1.LVS Server的IP配置:

VIP:

[root@LVS network-scripts]# cat ifcfg-eth0

DEVICE="eth0"

BOOTPROTO="static"

HWADDR="08:00:27:85:86:F7"

NM_CONTROLLED="yes"

ONBOOT="yes"

TYPE="Ethernet"

IPADDR=172.16.31.50

NETMASK=255.255.0.0

GATEWAY=172.16.0.1

 

DIP:

[root@LVS network-scripts]# cat ifcfg-eth1

DEVICE="eth1"

BOOTPROTO="static"

HWADDR="08:00:27:3F:47:E1"

NM_CONTROLLED="yes"

ONBOOT="yes"

TYPE="Ethernet"

IPADDR=192.168.31.254

NETMASK=255.255.255.0

GATEWAY=172.16.0.1

 

2.Web Server服务器IP配置

Node1的web服务器IP设置:

[root@node1 network-scripts]# cat ifcfg-eth0

DEVICE="eth0"

BOOTPROTO="static"

HWADDR="08:00:27:23:2F:87"

NM_CONTROLLED="yes"

ONBOOT="yes"

TYPE="Ethernet"

IPADDR=192.168.31.1

NETMASK=255.255.0.0

GATEWAY=172.16.0.1

 

Node2的web服务器IP设置:

[root@node2 network-scripts]# cat ifcfg-eth0

DEVICE="eth0"

BOOTPROTO="static"

HWADDR="08:00:27:E0:A1:67"

NM_CONTROLLED="yes"

ONBOOT="yes"

TYPE="Ethernet"

IPADDR=192.168.31.2

NETMASK=255.255.255.0

GATEWAY=172.16.0.1

 

五.配置LVS Server启用转发功能

[root@LVS ~]# vim /etc/sysctl.conf

net.ipv4.ip_forward = 1

 

[root@LVS ~]# sysctl -p

net.ipv4.ip_forward = 1

net.ipv4.conf.default.rp_filter = 1

net.ipv4.conf.default.accept_source_route =0

kernel.sysrq = 0

kernel.core_uses_pid = 1

net.ipv4.tcp_syncookies = 1

error: "net.bridge.bridge-nf-call-ip6tables"is an unknown key

error:"net.bridge.bridge-nf-call-iptables" is an unknown key

error:"net.bridge.bridge-nf-call-arptables" is an unknown key

kernel.msgmnb = 65536

kernel.msgmax = 65536

kernel.shmmax = 68719476736

kernel.shmall = 4294967296

 

服务器之间的时间尽量一致


六.启动默认http服务器

Node1和Node2:

[root@node1 ~]# service httpd start

Starting httpd:                                           [  OK  ]

[root@node2 ~]# service httpd start

Starting httpd:                                            [  OK  ]

设置好测试网页:

[root@node1 ~]# echo "node1.stu31.com"> /var/www/html/index.html

[root@node2 ~]# echo"node2.stu31.com" > /var/www/html/index.html

 

七.启用LVS-NAT模式的负载均衡

1.采用RR调度方法:

[root@LVS ~]# ipvsadm -A -t 172.16.31.50:80-s rr

[root@LVS ~]# ipvsadm -a -t 172.16.31.50:80-r 192.168.31.1 -m

[root@LVS ~]# ipvsadm -a -t 172.16.31.50:80-r 192.168.31.2 –m

 

2.浏览器测试:


wKiom1SjoUGTw5JcAAK41KT1YVQ541.jpg 


 wKioL1SjogGzbw5iAAM5RvSaBUM942.jpg

多刷新几次可以观察出可以轮流查询的!


3.采用WRR加权调度算法:

[root@LVS ~]# ipvsadm -E -t 172.16.31.50:80-s wrr

[root@LVS ~]# ipvsadm -e -t 172.16.31.50:80-r 192.168.31.2 -m -w 2

 

浏览器测试:

可以看出前两次查询都是node2服务器返回的结果

[root@LVS ~]# ipvsadm -L -n

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

 -> RemoteAddress:Port          Forward Weight ActiveConn InActConn

TCP 172.16.31.50:80 wrr

 -> 192.168.31.1:80             Masq    1      0         1        

 -> 192.168.31.2:80             Masq    2      0         3

 

我们将其中一台web服务器关闭

[root@node1 ~]# service httpd stop

Stopping httpd:                                            [  OK  ]

 

浏览器刷新测试:


[root@LVS ~]# ipvsadm -L -n

IP Virtual Server version 1.2.1 (size=4096)

Prot LocalAddress:Port Scheduler Flags

 -> RemoteAddress:Port          Forward Weight ActiveConn InActConn

TCP 172.16.31.50:80 wrr

 -> 192.168.31.1:80             Masq    1      0         2        

 -> 192.168.31.2:80             Masq    2      0         9

由此可以知道LVS Server无法监控后端服务器的健康状态。



本文转自 dengaosky 51CTO博客,原文链接:http://blog.51cto.com/dengaosky/1964516,如需转载请自行联系原作者

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
相关文章
|
7月前
|
负载均衡 前端开发 JavaScript
LVS-DR模式、keepalived、Nginx与Tomcat合作,打造动静分离,高效负载均衡与高可用性
为了采用这样的架构,你需要对LVS-DR、Keepalived、Nginx与Tomcat有一定的理解和掌握,同时也需要投入一些时间去研究和配置,但是一旦你把它运行起来,你将会发现,这一切都是值得的。
298 11
|
10月前
|
负载均衡 网络协议 Linux
LVS,软负载均衡
LVS(Linux Virtual Server)是一项广泛应用的负载均衡技术,由章文嵩博士于1998年发起,自Linux 2.4.24版本起成为官方内核的一部分。LVS通过四层负载均衡技术实现高性能、高可用的服务器集群,支持多种调度算法和工作模式(如D-NAT、full-NAT、IP隧道、DR),适用于HTTP、数据库等应用。相比7层负载均衡器(如Nginx、HAProxy),LVS具有更高的并发处理能力和更低的资源消耗,适合大规模流量分发。本期文章详细介绍了LVS的工作原理、优势与不足,并对比了常见的负载均衡产品,帮助读者根据具体需求选择合适的解决方案。
1371 5
LVS,软负载均衡
|
11月前
|
负载均衡 IDE Java
SpringBoot整合XXL-JOB【04】- 以GLUE模式运行与执行器负载均衡策略
在本节中,我们将介绍XXL-JOB的GLUE模式和集群模式下的路由策略。GLUE模式允许直接在线上改造方法为定时任务,无需重新部署。通过一个测试方法,展示了如何在调度中心配置并使用GLUE模式执行定时任务。接着,我们探讨了多实例环境下的负载均衡策略,确保任务不会重复执行,并可通过修改路由策略(如轮训)实现任务在多个实例间的均衡分配。最后,总结了GLUE模式和负载均衡策略的应用,帮助读者更深入理解XXL-JOB的使用。
605 9
SpringBoot整合XXL-JOB【04】-  以GLUE模式运行与执行器负载均衡策略
|
12月前
|
负载均衡 算法 Linux
LVS+Keepalived:实现高效软负载均衡的利器
本文介绍了如何使用LVS(Linux Virtual Server)和Keepalived搭建高可用负载均衡集群。LVS通过不同调度算法将请求转发给后端服务器,而Keepalived基于VRRP协议实现服务高可用,避免IP单点故障。具体步骤包括环境准备、安装配置ipvsadm和Keepalived、启动服务及测试。文中还详细解释了配置文件中的关键参数,并提供了故障转移测试方法。最后,文章简要对比了软件、硬件和云负载均衡方案的特点,帮助读者选择合适的负载均衡策略。
1672 4
|
运维 负载均衡 网络协议
LVS+Keepalived 负载均衡
LVS+Keepalived 负载均衡
367 8
LVS+Keepalived 负载均衡
|
域名解析 运维 负载均衡
LVS+Keepalived 负载均衡(二)28-1
【8月更文挑战第28天】LVS+Keepalived 负载均衡 配置 LVS VIP
257 5
|
负载均衡 网络协议 Linux
在Linux中, LVS三种模式的工作过程是什么?
在Linux中, LVS三种模式的工作过程是什么?
|
负载均衡 算法 Linux
在Linux中,LVS-NAT模式的原理是什么?
在Linux中,LVS-NAT模式的原理是什么?
|
负载均衡 网络协议
使用LVS搭建集群实现负载均衡(二)安装使用
【8月更文挑战第8天】使用LVS搭建集群实现负载均衡(二)安装使用
247 5
|
存储 负载均衡 算法
使用LVS搭建集群实现负载均衡(一)
【8月更文挑战第8天】使用LVS搭建集群实现负载均衡
652 5

热门文章

最新文章