设为首页 收藏本站
查看: 6251|回复: 0

[经验分享] LVS中ipvsadm的使用方法及NAT类型集群实现

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-5-29 09:17:03 | 显示全部楼层 |阅读模式
LVS中实现负载均衡调度的规则生成工具是ipvsadm,程序包就是ipvsadm。
安装:
在centos64位上安装ipvsadm:
#yum install ipvsadm –y
安装后键入#rpm –ql ipvsadm  显示出如下信息
#/etc/rc.d/init.d/ipvsadm  服务脚本
#/etc/sysconfig/ipvsadm-config  保存规则的配置文件
#/sbin/ipvsadm  主程序
#/sbin/ipvsadm-restore  从文件中恢复规则并生效的程序
#/sbin/ipvsadm-save  保存至文件程序的程序
#/usr/share/doc/ipvsadm-1.26
#/usr/share/doc/ipvsadm-1.26/README
#/usr/share/man/man8/ipvsadm-restore.8.gz  restore的man文档
#/usr/share/man/man8/ipvsadm-save.8.gz  save的man文档
#/usr/share/man/man8/ipvsadm.8.gz  主程序man文档

使用方法:
管理集群服务:创建、修改、删除

管理集群服务:
创建或修改:
ipvsadm -A|E -t|u|f service-address [-sscheduler]

-A: 添加
-E:修改

-t: 承载的应用层协议为基于TCP协议提供服务的协议;其service-address的格式为“VIP:PORT”,如“172.16.50.2:80”;
-u: 承载的应用层协议为基于UDP协议提供服务的协议;其service-address的格式为“VIP:PORT”,如“172.16.50.3:53”;
-f:承载的应用层协议为基于TCP或UDP协议提供服务的协议,但此类报文会经由iptables/netfilter打标记,即为防火墙标记;其service-address的格式为(一个数字即可)“FWM”,例如“10”;例如:可以将TCP的80端口标记上10、UDP的443端口标记上10从而将两个集群服务做成一个集群服务。
-s scheduler: 指明调度方法;默认为wlc;
举例:
wKioL1VmcxCydaziAACfRN2kd8o190.jpg
删除:
ipvsadm -D -t|u|f service-address
举例:
wKiom1Vmcanj4Wp0AABxrdiwhuk168.jpg
管理集群服务上的RS:
添加或修改:
ipvsadm -a|e -t|u|f service-address -rserver-address [-g|i|m] [-w weight]
-r server-address: 指明RS,server-address格式一般为“IP[:PORT]”;注意,只支持端口映射的lvs类型中才应该显式定义此处端口;例如:-r 172.16.50.1
[-g|i|m]: 指明lvs类型,默认为dr类型
-g: gateway, 意为dr类型;
-i: ipip, 意为tun类型;
-m: masquerade, 意为nat类型;
[-w weight]:当前RS的权重;注意:仅对于支持加权调度的scheduler,权重才有意义;
举例:
wKioL1Vmc32CWz1SAADGhdRYMgY222.jpg
删除:
ipvsadm -d -t|u|f service-address -rserver-address
举例:
wKiom1VmchvzGqBhAAEv-FQk8vw228.jpg
清空所有集群服务的定义:
ipvsadm –C
举例:
wKiom1VmckzRtlAXAABginaJ51E085.jpg
保存及恢复集群服务及RS的定义:
ipvsadm -S > /etc/sysconfig/ipvsadm或者ipvsadm-save> /etc/sysconfig/ipvsadm或者service ipvsadm save
举例:
wKiom1VmcnDQAz1hAADe3Iw18Q8789.jpg
ipvsadm -R < /etc/sysconfig/ipvsadm或者ipvsadm-restore< /etc/sysconfig/ipvsadm或者service ipvsadm restart
举例:
wKiom1Vmcq2CY3kyAAErvvZxgEE660.jpg
查看规则:
ipvsadm -L|l [options]
-c: 列出当前所有connection;
-n, --numeric: 数字格式显示IP及端口;
举例:
wKioL1VmdHbAS-52AACE5lZKCPY587.jpg
--stats: 列出统计数据
举例:
wKiom1VmcyawkNs6AACF7Of9wJM558.jpg
--rate: 列出速率
举例:
wKiom1Vmc1nRX9aEAAB87zynk5E634.jpg
--exact: 精确值;(据我看好像和没加这个参数显示的是一样的)
举例:
wKiom1Vmc3zCixS_AADpgqn9JTc221.jpg
清空计数器:
ipvsadm -Z [-t|u|f service-address]
举例:(真的会清哦)
wKioL1VmdTLDPUK2AAD0FB_7Wo0052.jpg
搭建NAT类型的web服务集群
如:要实现ipvs_nat类型的搭建,首先准备三个linux虚拟机,centos64位(简称:V1)用作director,centos64位(2)(简称:V2)、centos64位(3)(简称:V3)作为real server构建一个web服务集群。
由于具体实现调度功能的是ipvs,而ipvs工作在netfilter的input链上,则ipvs和iptables两者共同工作会产生冲突,所以,在集群存在的情况下,iptables一般应该关闭。
清除iptables规则并查看
wKioL1VmdWLxtUVkAABvSFsPU3E677.jpg
在V1
一个网卡以桥接方式(vmnet0)与物理机连接
wKioL1VmdYjhd8TEAAElHFf_dfA343.jpg
再添加一块网卡(vmnet2)以普通模式与V2、V3连接
wKiom1VmdCPwXtu6AAEoI3l93u0078.jpg
在V2、V3上修改网卡为wmnet2
wKiom1VmdE7jpa96AAEIBhEpsy0358.jpg
将V1中的vmnet2网卡eth1配置成192.168.50.1
wKiom1VmdKGQMmBgAADtIpP3zl0998.jpg

同样方法,将V2的vmnet2类型网络的eth0修改为192.168.50.2,V3中vmnet2类型网络的eth0修改为192.168.50.3
设置网关为192.168.50.1并查看
wKiom1VmdOGz2QNXAACDhweDxUE759.jpg
分别用V2、V3测试与V1外网地址的连通性
wKioL1Vmdpnipa9wAACjOcIxYL0818.jpg
注:若想永久有效可以在V2、V3的/etc/sysconfig/network-scripts/ifcfg-eth0添加
IPADDR=192.168.50.2
NETMASK-255.255.255.0
GATEWAY=192.168.50.1
BOOTPROTO=”none”
在V1中测试与V2、V3的连通性
ping -c 1 192.168.50.2
ping -c 1 192.168.50.3
wKiom1VmdT-SyP0-AAD5gojqjHg612.jpg
保证在V2、V3上安装好了httpd,并在V2、V3上编辑网页
vim /var/www/html/index.html
wKioL1VmdxeCx9V2AAAW3MmnTWU231.jpg
wKiom1VmdYaxmf61AAAVBzrS-oA513.jpg
wKioL1VmdxiQaw5eAAAYWyo4mwI812.jpg


然后启动http服务
service httpd start
然后在V1上测试下是否可以访问V2、V3的网页
curl http://192.168.50.2
curl http://192.168.50.3
wKiom1Vmdc_DHpKhAAA_xDsqjd4108.jpg
见到上述页面,即可以在V1主机上配置ipvs规则了
wKioL1Vmd4vzABRDAADEE1WiwuE108.jpg
打开V1中的路由转发功能
vim /etc/sysctl.conf
将net.ipv4.ip_forward = 0改成1
wKioL1Vmd9PA53WaAAA7m9t36Ok536.jpg
让sysctl的配置立即生效
sysctl –p
wKioL1Vmd_myfKBqAADh2rEBOQk418.jpg
在主机浏览器中输入172.16.50.1,重复刷新看是否轮询即可。

这样基于rr规则的lvs负载均衡集群就搭建完成喽!
也可以更换规则类型实现基于其他规则的负载均衡。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-71768-1-1.html 上篇帖子: LVS详解及基于LVS实现web服务器负载均衡 下篇帖子: Keepalived与LVS
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表