码迷,mamicode.com
首页 > 其他好文 > 详细

LVS中ipvsadm的使用方法及NAT类型集群实现

时间:2015-05-28 14:26:10      阅读:686      评论:0      收藏:0      [点我收藏+]

标签:负载均衡 集群 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  restoreman文档

#/usr/share/man/man8/ipvsadm-save.8.gz  saveman文档

#/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:承载的应用层协议为基于TCPUDP协议提供服务的协议,但此类报文会经由iptables/netfilter打标记,即为防火墙标记;其service-address的格式为(一个数字即可)“FWM”,例如“10”;例如:可以将TCP80端口标记上10UDP443端口标记上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: 指明RSserver-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)用作directorcentos64位(2)(简称:V2)、centos64位(3)(简称:V3)作为real server构建一个web服务集群。

由于具体实现调度功能的是ipvs,而ipvs工作在netfilterinput链上,则ipvsiptables两者共同工作会产生冲突,所以,在集群存在的情况下,iptables一般应该关闭。

清除iptables规则并查看

技术分享

V1

一个网卡以桥接方式(vmnet0)与物理机连接

技术分享

再添加一块网卡(vmnet2)以普通模式与V2V3连接

技术分享

V2V3上修改网卡为wmnet2

技术分享

V1中的vmnet2网卡eth1配置成192.168.50.1

技术分享


同样方法,将V2vmnet2类型网络的eth0修改为192.168.50.2V3vmnet2类型网络的eth0修改为192.168.50.3

设置网关为192.168.50.1并查看

技术分享

分别用V2V3测试与V1外网地址的连通性

技术分享

注:若想永久有效可以在V2V3/etc/sysconfig/network-scripts/ifcfg-eth0添加

IPADDR=192.168.50.2

NETMASK-255.255.255.0

GATEWAY=192.168.50.1

BOOTPROTO=”none”

V1中测试与V2V3的连通性

ping -c 1 192.168.50.2

ping -c 1 192.168.50.3

技术分享

保证在V2V3上安装好了httpd,并在V2V3上编辑网页

vim /var/www/html/index.html

技术分享

技术分享

技术分享



然后启动http服务

service httpd start

然后在V1上测试下是否可以访问V2V3的网页

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负载均衡集群就搭建完成喽!

也可以更换规则类型实现基于其他规则的负载均衡。

 

妈蛋~写这么多累死了!


LVS中ipvsadm的使用方法及NAT类型集群实现

标签:负载均衡 集群 nat

原文地址:http://cthlj.blog.51cto.com/9694348/1655845

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!