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

本文涉及的产品
公网NAT网关,每月750个小时 15CU
简介:

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,如需转载请自行联系原作者

相关文章
|
21天前
|
域名解析 移动开发 负载均衡
阿里云DNS常见问题之DNS负载均衡调加权模式失败如何解决
阿里云DNS(Domain Name System)服务是一个高可用和可扩展的云端DNS服务,用于将域名转换为IP地址,从而让用户能够通过域名访问云端资源。以下是一些关于阿里云DNS服务的常见问题合集:
|
4月前
|
负载均衡 网络协议 网络架构
VRRP负载均衡模式配置实用吗?
VRRP负载均衡模式配置实用吗?
65 0
|
4月前
|
网络协议 Linux 网络架构
Linux三种网络模式 | 仅主机、桥接、NAT
Linux三种网络模式 | 仅主机、桥接、NAT
164 0
|
6月前
|
Linux 虚拟化
VMware安装Linux虚拟机之NAT模式网络配置图文详解
VMware安装Linux虚拟机之NAT模式网络配置图文详解
138 0
|
6月前
|
负载均衡 应用服务中间件 Linux
企业实战(13)LVS负载均衡NAT(网络地址转换)模式实战详解(一)
企业实战(13)LVS负载均衡NAT(网络地址转换)模式实战详解(一)
|
6月前
|
存储 负载均衡 网络协议
企业实战(13)LVS负载均衡DR(直接路由)模式实战详解(二)
企业实战(13)LVS负载均衡DR(直接路由)模式实战详解(二)
103 0
|
5月前
|
负载均衡 应用服务中间件 Linux
Nginx系列教程(14) - LVS+KeepAlived+Nginx实现高性能负载均衡集群
Nginx系列教程(14) - LVS+KeepAlived+Nginx实现高性能负载均衡集群
174 0
|
9天前
|
Linux 虚拟化
VMware workstation 中centos7虚拟机在nat模式下怎么配置网卡,指定我想要的IP并且可以联网
https://blog.csdn.net/2302_78534730/article/details/132825156?spm=1001.2014.3001.5502
131 0
|
3月前
|
网络协议 虚拟化 网络架构
桥接模式和NAT模式的区别
桥接模式和NAT模式的区别
|
3月前
|
网络安全 虚拟化 Windows
RHEL7-NAT模式连接外部网络
RHEL7-NAT模式连接外部网络
22 1