热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

linux下ipvsadm命令,Linux命令:ipvsadm

ipvsadm命令简介:ipvsadm是LVS在应用层的管理命令,我们可以通过这个命令去管理LVS的配置。在fedora14、Linux6.0之后系统中

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_ignoreecho 1 > /proc/sys/net/ipv4/conf/lo/arg_ignoreecho 2 > /proc/sys/net/ipv4/conf/all/arg_announceecho 2 > /proc/sys/net/ipv4/conf/lo/arg_announce设置后,使得各个接口只对本接口上的地址进行响应4.2.2、在真实服务器上添加虚拟IPifconfig lo:0 192.168.10.10 boradcast 207.175.44.110 netmask 255.255.255.255ip 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---



推荐阅读
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 在Linux系统中,网络配置是至关重要的任务之一。本文详细解析了Firewalld和Netfilter机制,并探讨了iptables的应用。通过使用`ip addr show`命令来查看网卡IP地址(需要安装`iproute`包),当网卡未分配IP地址或处于关闭状态时,可以通过`ip link set`命令进行配置和激活。此外,文章还介绍了如何利用Firewalld和iptables实现网络流量控制和安全策略管理,为系统管理员提供了实用的操作指南。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文详细介绍了 Dockerfile 的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了 Docker 的默认网络、容器互联及自定义网络的实现。 ... [详细]
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文汇总了在正式宴会上常用的寒暄语句,包括欢迎词、感谢词及日常问候,适用于各种正式场合。这些语句不仅有助于提升交际礼仪,还能增进彼此之间的友好关系。 ... [详细]
  • 在分析和解决 Keepalived VIP 漂移故障的过程中,我们发现主备节点配置如下:主节点 IP 为 172.16.30.31,备份节点 IP 为 172.16.30.32,虚拟 IP 为 172.16.30.10。故障表现为监控系统显示 Keepalived 主节点状态异常,导致 VIP 漂移到备份节点。通过详细检查配置文件和日志,我们发现主节点上的 Keepalived 进程未能正常运行,最终通过优化配置和重启服务解决了该问题。此外,我们还增加了健康检查机制,以提高系统的稳定性和可靠性。 ... [详细]
  • Keepalived 提供了多种强大且灵活的后端健康检查机制,包括 HTTP_GET、SSL_GET、TCP_CHECK、SMTP_CHECK 和 MISC_CHECK 等多种检测方法。这些健康检查功能确保了高可用性环境中的服务稳定性和可靠性。通过合理配置这些检查方式,可以有效监测后端服务器的状态,及时发现并处理故障,从而提高系统的整体性能和可用性。 ... [详细]
author-avatar
小白秋波_314
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有