博客统计信息

51cto推荐博客
用户名:linuxtro
文章数:73
评论数:107
访问量:69787
无忧币:1189
博客积分:1642
博客等级:6
注册日期:2010-02-05

基于LVS-DR集群的持久链接实验
2010-03-17 09:28:33
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://linuxtro.blog.51cto.com/1239505/284510
 
前期准备:
试验环境 Red Hat Enterprise Linux 5
软件版本 ipvsadm-1.25.tar.gz
搭建实验环境,三台虚拟机,一台作为Director、两台作为RealServer
通过yum库安装ipvsadm软件包,并配置各个物理网卡地址成为:
DIP:192.168.0.43 RIP1:192.168.0.45 RIP2:192.168.0.46,网关为:192.168.0.47
LVS-DR持续链接网络拓扑图
clip_image002
打开Director的路由转发功能(在实际应用中,DIP和VIP处于不同的网段,所以要打开路由转发功能)。
clip_image003
ifconfig eth0:0 192.168.0.49 broadcast 192.168.0.49 netmask 255.255.255.255 up
route add –host 192.168.0.49 dev eth0:0
clip_image005
clip_image007
所以要配置Iptables规则来标记通过防火墙的数据请求。添加完成后要查看一下是否添加成功。
clip_image009
clip_image011
接下来就是加载Director的Rules规则:
添加一条ipvsadm规则,这是一条使用防火墙标记的基于加权最少活动链接的默认持久链接为600秒的ipvsadm规则。配置完成后用ipvsadm –L –n 命令查看刚才配置好的规则。
clip_image013
添加ipvsadm规则,这是一条使用防火墙标记为1的RIP为192.168.0.45的权重为1的基于LVS-DR转发类型的ipvsadm规则。第二条规则的RIP为192.168.0.46,权重为2,配置完成后查看刚刚配置好的规则。
clip_image015
RealServer服务器配置:
重启一下本地换回地址。
clip_image017
将RealServer1的VIP绑定到本地环回地址:
ifconfig lo:0 192.168.0.49 broadcast 192.168.0.49 netmask 255.255.255.255 up
并添加环回路由,route add –host 192.168.0.49 dev lo:0
clip_image019
当CIP发出需找VIP的ARP广播求情时,为了避免RealServer响应ARP请求,需要隐藏RealServer的VIP,具体命令如下图所示:
因为本地网卡和换回地址网卡处于不同的文件中,所以要分别导入这两个文件。
clip_image023clip_image021
RealServer1的配置也结束了,接着就是重启web服务。确保本机测试可以正常访问。
RealServer2的服务配置与RealServer1相同,在此演示步骤省略。
测试配置:
选择一台主机,ip设置192.168.0.42 ,来访问http://192.168.0.49, 测试一下刚才的劳动成果。反复刷新网页,每次出现的网页不同则表示成功。
(此处显示的以http://开头是为了和后面的配置进行对比。与本次试验无关)
clip_image025
在Director上连续执行ipvsadm –L –n命令,可以发现链接到RealServer服务器的数据变化,并且是只有一台RealServer服务器的数据发生变化,另一台RealServer的链接数一直保持为0.此时,我们就可以宣布试验成功了。庆祝一下吧?^_^
还记得试验目的吧?就是实现基于LVS-DR的持久链接,这个链接时间是刚才我们在Director上配置的600秒。过了600秒以后,再到客户端上继续刷新,有可能会链接到192.168.0.45,也有可能会是192.168.0.46
clip_image027
再来设置一种新假设。如果客户端的访问请求是链接到电子商务类网站,需要输入网上货币流通,此时对RealServer服务的要求就是要保证数据的安全性,防止信息的泄露。那么RealServer服务器端要做的就是增加web服务的访问安全机制。这该如何设置呢?
我们可以使用基于安全目标tcp通道的https协议。这就要在RealServer上分别配置基于SSL的证书来认证(有关签证可以参考本人另一篇博客《如何实现安全web服务》)。
验证结果为:
clip_image029
clip_image031
clip_image033
再打开另外一台客户端来连接RealServer的web服务,保持两台客户端不断刷新页面。切换到Director机器上,执行ipvsadm –L –n来查看访问的数据请求。可以发现两台RealServer都接受到了数据访问。
clip_image035

本文出自 “linux on the way” 博客,请务必保留此出处http://linuxtro.blog.51cto.com/1239505/284510

分享至
更多
一键收藏,随时查看,分享好友!
zhu833、freehat08、carzybao
3人
了这篇文章
类别:LVS集群技术圈()┆阅读()┆评论() ┆ 推送到技术圈返回首页

文章评论

 
2010-03-18 08:59:58
做得很不错!
博主回复:
2010-03-18 09:13:37
谢谢,和大家一块学习!

2010-03-23 19:51:53
感谢某热心网友提出的意见,在文章开头有一句话是“打开Director的路由转发功能”,其作用是转发DIP和VIP之间的数据信息。在实际应用中,DIP为私有IP地址,VIP为公网IP地址,两者处于不同的网段,所以需要开启Director的路由转发功能。

2011-06-16 22:56:24
兄弟写的很棒,学习了

2011-07-15 15:14:40
你好,看了你的文章受益匪浅。但同时,也有一个问题请教。
在持久链接的情况下,客户端链接上服务器,客户端因为长久不用,出现持久超时,这时候在Director上的这条持久链接会被删除,这时候Director会发送fin包给客户端和realserver关闭当前链接吗?

 

发表评论            

【技术门诊】专家解析:软考重点难点及应试技巧
昵  称:
登录  快速注册
验证码:

请点击后输入验证码博客过2级,无需填写验证码

内  容: