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

[经验分享] Linux命令:ipvsadm

[复制链接]
累计签到:2 天
连续签到:1 天
发表于 2018-5-17 09:51:02 | 显示全部楼层 |阅读模式
ipvsadm 命令简介:

ipvsadm是LVS在应用层的管理命令,我们可以通过这个命令去管理LVS的配置。在fedora14、Linux6.0之后系统中,已经集成了LVS相关模块,但是ipvsadm命令仍然需要使用yum单独安装。
  

1.命令格式:

ipvsadm COMMAND [protocol] service-address [scheduling-method] [persistence options]
  ipvsadm command [protocol] service-address server-address [packet-forwarding-method] [weight options]

第一条命令用于向LVS系统中添加一个用于负载均衡的virtual server(VS);
第二条命令用来修改已经存在的VS的配置,service address用来指定涉及的虚拟服务即虚拟地址,server-address指定涉及的真实地址。


2.命令:
  -A, --add-service:  为ipvs虚拟服务器添加一个虚拟服务,
  即添加一个需要被负载均衡的虚拟地址。虚拟地址需要是ip地址,端口号,协议的形式。

  -E, --edit-service:  修改一个虚拟服务。
  -D, --delete-service: 删除一个虚拟服务。
  -C, --clear:     清除所有虚拟服务。
  -R, --restore:  从标准输入获取ipvsadm命令。一般结合下边的-S使用。
  -S, --save:从标准输出输出虚拟服务器的规则。
  可以将虚拟服务器的规则保存,在以后通过-R直接读入,以实现自动化配置。
  

  -a, --add-server:   为虚拟服务添加一个real server(RS)
  -e, --edit-server:  修改RS
  -d, --delete-server:  删除
  -L, -l, --list:  列出虚拟服务表中的所有虚拟服务。可以指定地址。添加-c显示连接表。
  -Z, --zero:   将所有数据相关的记录清零。这些记录一般用于调度策略。
  --set tcp tcpfin udp: 修改协议的超时时间。
  --start-daemon state: 设置虚拟服务器的备服务器,用来实现主备服务器冗余(只支持ipv4)
  --stop-daemon:  停止备服务器。
  -h, --help:  帮助。
  

  

      3.参数:
  

  -t, --tcp-service
  service-address:指定虚拟服务为tcp,要是host[:port]形式,端口是0表示任意端口,如将端口设为0,需要加上-p(持久连接)
  -u, --udp-service service-address: 使用udp服务,其他同上。
  

  -f, --fwmark-service integer:
  用firewall mark取代虚拟地址来指定要被负载均衡的数据包,可以通过这个命令实现把不同地址、端口的虚拟地址整合成一个虚拟服务,可以让虚拟服务器同时截获处理去往多个不同地址的数据包。fwmark可以通过iptables命令指定。如果用在ipv6需要加上-6。
  

  -s, --scheduler scheduling-method:指定调度算法。可指定以下几种:
  rr(轮询),wrr(权重),    lc(最后连接),wlc(权重),
  lblc(本地最后连接),lblcr(带复制的本地最后连接),
  dh(目的地址哈希),sh(源地址哈希),  sed(最小期望延迟),nq(永不排队)
  

  -p, --persistent [timeout]:设置持久连接,
  这个模式可以使来自客户的多个请求被送到同一个真实服务器,通常用于ftp或者ssl中。
  -M, --netmask netmask:指定客户地址的子网掩码。用于将同属一个子网的客户的请求转发到相同服务器。
  

  -r, --real-server server-address:为虚拟服务指定数据可以转发到的真实服务器的地址。可以添加端口号。如果没有指定端口号,则等效于使用虚拟地址的端口号。
  [packet-forwarding-method]: 指定真实服务器所用的数据转发模式。需对每个RS分别指定。
  -g, --gatewaying: 使用网关(即直接路由),此模式是默认模式。
  -i, --ipip:     使用ipip隧道模式。
  -m, --masquerading: 使用NAT模式。
  

  -w, --weight weight:设置权重。  权重是0~65535的整数。
  如权重设置为0,那它不会收到新的连接,但已有连接还会继续维持(这和直接把某个RS删除不同)
  -x, --u-threshold uthreshold:设置服务器可维持的连接上限。0~65535。0表示没有上限。
  

  -y, --l-threshold lthreshold: 设置服务器的连接下限。
  当服务器的连接数低于此值的时候服务器才可以重新接收连接。如果此值未设置,则当服务器的连接数连续三次低于uthreshold时服务器才可以接收到新的连接。(PS:笔者以为此设定可能是为了防止服务器在能否接收连接这两个状态上频繁变换)
  --mcast-interface interface:  指定使用备服务器时候的广播接口。
  --syncid syncid:   指定syncid,同样用于主备服务器的同步。
  

  

  以下选项用于list命令:
  -c, --connection:列出当前的IPVS连接。
  --timeout:列出超时
  --daemon:
  --stats:状态信息
  --rate:传输速率
  --thresholds:列出阈值
  --persistent-conn:坚持连接
  --sor:把列表排序。
  --nosort:不排序
  -n, --numeric:不对ip地址进行dns查询
  --exact:单位
  -6:如果fwmark用的是ipv6地址需要指定此选项。
  

  

  其他注意事项
  1、如果使用IPv6地址,需要在地址两端加  "[  ]"
  如:ipvsadm -A -t [2001:db8::80]:80 -s rr
  2、可通过设置以下虚拟文件的值来防御DoS攻击:
  /proc/sys/net/ipv4/vs/drop_entry
  /proc/sys/net/ipv4/vs/drop_packet
  /proc/sys/net/ipv4/vs/secure_tcp
  

  

  4、实例:
  

  4.1.使用NAT模式
  添加地址为207.175.44.110:80的虚拟服务,指定调度算法为轮转。
  ipvsadm -A -t 207.175.44.110:80 -s rr
  添加真实服务器,指定传输模式为NAT
  ipvsadm -a -t 207.175.44.110:80 -r 192.168.10.1:80 -m
  ipvsadm -a -t 207.175.44.110:80 -r 192.168.10.2:80 -m
  ipvsadm -a -t 207.175.44.110:80 -r 192.168.10.3:80 -m
  NAT模式是lvs的三种模式中最简单的一种。此种模式下只需要保证调度服务器与真实服务器互通就可以运行。
  

  4.2.使用DR模式
  对于DR模式首先要配置真实服务器:
  对于每台真实服务器要进行以下操作:
  4.2.1、设置真实服务器的lo接口不做ARP应答
echo 1 > /proc/sys/net/ipv4/conf/all/arg_ignore
echo 1 > /proc/sys/net/ipv4/conf/lo/arg_ignore
echo 2 > /proc/sys/net/ipv4/conf/all/arg_announce
echo 2 > /proc/sys/net/ipv4/conf/lo/arg_announce
设置后,使得各个接口只对本接口上的地址进行响应
4.2.2、在真实服务器上添加虚拟IP
ifconfig lo:0 192.168.10.10 boradcast 207.175.44.110 netmask 255.255.255.255
ip r add 192.168.10.10 dev lo
  接着添加ipvs规则:
  添加地址为192.168.10.10:80的虚拟服务,指定调度算法为轮转。
  ipvsadm -A -t 192.168.10.10:80 -s rr
  添加真实服务器,指定传输模式为DR
  ipvsadm -a -t 192.168.10.10:80 -r 192.168.10.1:80 -g
  ipvsadm -a -t 192.168.10.10:80 -r 192.168.10.2:80 -g
  ipvsadm -a -t 192.168.10.10:80 -r 192.168.10.3:80 -g
  注意:此处的例子中客户、调度服务器、真实服务器都是位于同一网段的
  

---end---


运维网声明 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-461206-1-1.html 上篇帖子: Linux目录结构小结 下篇帖子: Linux 系统使用建议
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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