LVS的持久连接

   不论你用的什么调度算法,在一定时间内来之同一个客户的请求都会发给同一个服务器,默认连接超时是360秒,但这个值你可以自己定义,如果超时后,客户的连接依然存在,则默认以2分钟的方式依次增加。

持久连接的类型

(1)PCC 将某个客户的所用访问请求在超时时间内都定向到同一台server上 基于客户端的持久连接

(2)PPC 将某个客户的某个服务访问请求在超时时间内都定向到同一台server上 基于会话的持久连接

(3)Netfilter Mark  基于防火墙标志的持久连接

PCC例子

director上配置

Ipvsadm  -A -t 192.168.2.1:0 -s  rr  -p  360

Ipvsadm  -a  -t 192.168.2.1:0 -r 192.168.2.100 -g

Ipvsadm  -a  -t 192.168.2.1:0 -r 192.168.2.200 -g

查看

LVS的持久连接_第1张图片

通过访问vip地址 192.168.2.1再次查看

LVS的持久连接_第2张图片

连接一直处在192.168.2.200server

  

PPC的例子

当访问80端口使定向到2.100,当访问22端口是定向到2.1002.200

ipvsadm -C --清空上述的配置

 ipvsadm -A -t 192.168.2.1:22 -s rr -p 

 ipvsadm -A -t 192.168.2.1:80 -s rr -p 

ipvsadm -a -t 192.168.2.1:22 -r 192.168.2.100 -g

ipvsadm -a -t 192.168.2.1:22 -r 192.168.2.200 -g

ipvsadm -a -t 192.168.2.1:80 -r 192.168.2.100 -g

查看

LVS的持久连接_第3张图片

访问vip80端口http://192.168.2.1/再次查看如下

LVS的持久连接_第4张图片

访问vip22端口ssh://192.168.2.10:22 查看如下:

LVS的持久连接_第5张图片

Netfilter Mark 例子

对于电子商务网站来说,用户在挑选商品的时候使用的是80端口来浏览的,当付款的时候则是通过443ssl加密的方式,当然当用户挑选完商品付款的时候我们当然不希望https443跳转到另外一台REALSERVER,很显然应该是同一REALSERVER才对。通过基于防火墙标记的持久连接来实现

首先在两台server上搭建CA认证中心,并为web站点颁发证书,以实现https,关于这部分内容请参考前期的博文,这里就不写了。

1、在iptables添加规则,给客户的请求打上标签

iptables  -t mangle -A PREROUTING  -d 192.168.2.1 -i eth0  -p tcp -m multiport --dport 80,443 -j MARK --set-mark 10  --把从eth0进来的到192.168.2.1去的目标端口为80443的打上标签10

2、虚拟规则

ipvsadm -C 

ipvsadm -A -f 10 -s  rr  -p    --f    firewallMark

ipvsadm -a -f 10 -r 192.168.2.100 -g

ipvsadm -a -f 10 -r 192.168.2.200 -g  

LVS的持久连接_第6张图片

通过访问vip的端口80443  http://192.168.2.1/https://192.168.2.1/ 再看如下

LVS的持久连接_第7张图片

如果后方的服务是FTP服务,怎么才能持久连接呢

这里的FTP服务是PSAV模式,其中21端口是控制端口,20端口是数据传输端口。

被动连接是FTP服务器从大于1024端口中选取一个作为回应端口号,因此我们要限制一下

这个回应端口号的范围。

vim /etc/vsftpd/vsftpd.conf

pasv_min_port=2000

pasv_max_port=2100

[root@localhost ~]# iptables  -t mangle -A PREROUTING -i eth0 -d 192.168.2.1 -p tcp --dport 21 -j MARK --set-mark 10

[root@localhost ~]# iptables  -t mangle -A PREROUTING -i eth0 -d 192.168.2.1 -p tcp --dport 2000:2100 -j MARK --set-mark 10

[root@localhost ~]# ipvsadm -A -f 10 -s rr -p

[root@localhost ~]# ipvsadm -a -f 10 -r 192.168.2.100 -g

[root@localhost ~]# ipvsadm -a -f 10 -r 192.168.2.200 -g

访问我的VIPFTP服务

LVS的持久连接_第8张图片

在用另一台client访问一下就会定向到192.168.2.100这台ftp服务器上。 

上述的访问或登录都没截图,给人感觉贴上有点乱,但是都是验证过的!!!