标签:负载均衡 集群 nat
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;
举例:
删除:
ipvsadm -D -t|u|f service-address
举例:
管理集群服务上的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,权重才有意义;
举例:
删除:
ipvsadm -d -t|u|f service-address -rserver-address
举例:
清空所有集群服务的定义:
ipvsadm –C
举例:
保存及恢复集群服务及RS的定义:
ipvsadm -S > /etc/sysconfig/ipvsadm或者ipvsadm-save> /etc/sysconfig/ipvsadm或者service ipvsadm save
举例:
ipvsadm -R < /etc/sysconfig/ipvsadm或者ipvsadm-restore< /etc/sysconfig/ipvsadm或者service ipvsadm restart
举例:
查看规则:
ipvsadm -L|l [options]
-c: 列出当前所有connection;
-n, --numeric: 数字格式显示IP及端口;
举例:
--stats: 列出统计数据
举例:
--rate: 列出速率
举例:
--exact: 精确值;(据我看好像和没加这个参数显示的是一样的)
举例:
清空计数器:
ipvsadm -Z [-t|u|f service-address]
举例:(真的会清哦)
搭建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规则并查看
在V1
一个网卡以桥接方式(vmnet0)与物理机连接
再添加一块网卡(vmnet2)以普通模式与V2、V3连接
在V2、V3上修改网卡为wmnet2
将V1中的vmnet2网卡eth1配置成192.168.50.1
同样方法,将V2的vmnet2类型网络的eth0修改为192.168.50.2,V3中vmnet2类型网络的eth0修改为192.168.50.3
设置网关为192.168.50.1并查看
分别用V2、V3测试与V1外网地址的连通性
注:若想永久有效可以在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
保证在V2、V3上安装好了httpd,并在V2、V3上编辑网页
vim /var/www/html/index.html
然后启动http服务
service httpd start
然后在V1上测试下是否可以访问V2、V3的网页
curl http://192.168.50.2
curl http://192.168.50.3
见到上述页面,即可以在V1主机上配置ipvs规则了
打开V1中的路由转发功能
vim /etc/sysctl.conf
将net.ipv4.ip_forward = 0改成1
让sysctl的配置立即生效
sysctl –p
在主机浏览器中输入172.16.50.1,重复刷新看是否轮询即可。
这样基于rr规则的lvs负载均衡集群就搭建完成喽!
也可以更换规则类型实现基于其他规则的负载均衡。
妈蛋~写这么多累死了!
标签:负载均衡 集群 nat
原文地址:http://cthlj.blog.51cto.com/9694348/1655845