Linux命令:ipvsadm

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---

时间: 2024-08-13 21:46:18

Linux命令:ipvsadm的相关文章

linux命令单次或组合样例

[[email protected] ~]# which passwd/usr/bin/passwd[[email protected] ~]# whereis passwdpasswd: /usr/bin/passwd /etc/passwd /usr/share/man/man1/passwd.1.gz /usr/share/man/man5/passwd.5.gz[[email protected] ~]# locate passwd/etc/passwd/etc/passwd-/etc/

linux命令格式,获取帮助及其目录结构简要理解

我们都知道,一台计算机要是没通电,和一堆废铁没什么区别.那么,通电开机进入系统后,会进入交互界面,等待用户操作,人与计算机交互界面有两种: GUI:图形用户接口.如我们平时使用的Windows  ,linux的X window,有KDE和GOME. CLI:命令行接口,使用的SHELL类型有bash ,csh,tcshell,zshell等. 例如:[[email protected] ~]# commandbin root:当前登录的用户名. dxlcentOS:当前主机的主机名.@是一个分隔

linux 命令 及学习进度综合整理

linux  命令  及学习进度综合整理 pwd 查看当前所在位置 cd  跳转到什么什么目录 ls  显示所有文件和目录 ls -l  显示目录详细信息 cd ..  返回上一级 vi  lnany.txt  创建一个文件 vi  .lnany.txt    创建一个隐藏文件 vim 是 vi 的升级版 功能更多 出现 -bash: vim: command not found 的解决办法 i. 那么如何安裝 vim 呢?输入rpm -qa|grep vim 命令, 如果 vim 已经正确安裝

9个使用时必须时刻警惕的Linux命令

Linux shell/terminal命令非常强大,即使一个简单的命令就可能导致文件夹.文件或者路径文件夹等被删除.为了避免这样的事情发生,我们应该时刻注意PHP代码&命令,今天为大家带来9个必须时刻警惕的Linux命令&代码. Linux shell/terminal 命令非常强大,即使一个简单的命令就可能导致文件夹.文件或者路径文件夹等被删除. 在一些情况下,Linux 甚至不会询问你而直接执行命令,导致你丢失各种数据信息. 一般来说在 Web 上推荐新的 Linux 用户执行这些命

Linux命令之scp

Linux命令之scp 功能说明 scp 是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且 scp传输是加密的.可能会稍微影响一下速度.当你服务器硬盘变为只读 read only system时,用scp可以帮你把文件移出来.另 外,scp还非常不占资源,不会提高多少系统负荷,在这一点上,rsync就远远不及它了.虽然 rsync比scp会快一点,但当小文件众多的情况 下,rsync会导致硬盘I/O非常高

linux命令--top命令&free命令

top命令是用来查看系统性能的工具,能够实时显示各个进程的状况,包括进程ID.内存占用率.CPU占用率等. top - 23:12:04 up 79 days,  8:14,  1 user,  load average: 0.00, 0.01, 0.05 Tasks: 573 total,   2 running, 571 sleeping,   0 stopped,   0 zombie Cpu(s):  0.2%us,  0.4%sy,  0.0%ni, 99.5%id,  0.0%wa,

linux命令学习笔记

操作文件和目录: copy: $ cp file1 file2 $ cp -r dir1 dir2 move: $ mv file .. $ mv file dir/ rename: $ mv file1 file2 $ mv dir1 dir2 # dir2如果存在,则为移动操作 remove: $ rm file $ rm -r dir 创建文件: $ touch a.txt $ >a.txt 创建目录: $ mkdir dir 查看文件: #一般 $ cat file #查看文件类型: $

cv:显示Linux命令运行进度

cv: 显示 cp.mv 等命令的进度 2014-07-14 By toy Posted in Apps Edit on GitHub 在 Linux 系统中 , 大多数命令从来都是信奉 “ 沉默是金 ” 的准则 , 所以当我们利用 cp 复制文件的时候并不能看到所谓的进度条 . 如果你在意这一点 , 那么不妨来用用 cv. cv 是 Coreutils Viewer, 它能够显示传输数据的进度 , 包括百分比 . 大小 . 以及速率等信息 .cv 支持 coreutils 中的基本命令 , 比

三个网站让你成为Linux命令行高手

[转载自http://www.linuxeden.com/html/news/20091119/69183.html] Linux的命令行是通向Linux高级应用的必经之路,Linux系统管理员.开发者都是学习对象.Susan Linton向我们推荐了三个学习Linux命令行的网站,现在介绍给大家: 1. LinuxCommand LinuxCommand是一个学习Linux命令行最好的网站之一.网站分为:学习Shell.写Shell脚本.脚本库.超级MAN页面. 2. O'Reilly的Lin

linux 命令解析2

基本命令  uname -a -s hostname显示主机名若是要永久生效,则编辑以下文件  #vim /etc/sysconfig/network    ssh远程登录#ssh 10.1.1.54 (是以root用户登录的)  #ssh [email protected](是以tom身份登录)  #ssh -Y 10.1.1.54(可以启动图形界面的远程登陆) scp远程拷贝  #scp 10.1.1.54:/etc/passwd /tmp/test(将目的地址10.1.1.54上的/etc