【Linux】Bonding配置,管理
2023-09-14 08:57:29 时间
1 通过Ifenslave手动配置Bonding
该方法适用于某些发行包,它们的网络初始化脚本(sysconfig或initscripts包)没有bonding相关的知识。SuSE Linux Enterprise Server 版本8就是这样的一个发行包。
对于这些系统一般的方法是,把bonding模块的参数放进/etc/modules.conf或者/etc/modprobe.conf(针对不同的安装发行包),然后在系统的全局初始化脚本里增加modprobe和/或ifenslave命令。对于sysconfig,全局初始化脚本是/etc/init.d/boot.local,而对于initscripts,它是/etc/rc.d/rc.local。
比如,如果你想要实现一个简单的带两个e100设备(比如eth0和eth1)的bond,而且希望它在重启后还能存在,那么编辑对应的文件(/etc/init.d/boot.local或/etc/rc.d/rc.local),在里面加上:
modprobe bonding mode=balance-alb miimon=100
modprobe e100
ifconfig bond0 192.168.1.1 netmask 255.255.255.0 up
ifenslave bond0 eth0 eth1
把示例里bonding模块参数以及bond0的网络配置(IP地址,掩码等)修改为对应系统的正确配置,不幸的是,这个方法不提供对bond设备上的ifup和ifdown脚本支持,为了重新加载bonding配置,你必须运行初始化脚本,比如:
# /etc/init.d/boot.local
# /etc/rc.d/rc.local
针对这种情况,理想的做法是,创建一个独立的脚本用于初始化bonding配置,然后在boot.local中调用这个独立的脚本,这样就可以不重启整个全局初始化脚本就打开bonding。
为了关闭bonding设备,你首先需要把bonding设备标记为正在关闭,然后移除对应的设备驱动模块。针对我们上面的例子,你可以这样关闭:
# ifconfig bond0 down
# rmmod bonding
# rmmod e100
同样的,方便起见,最好把这些命令创建在一个独立的脚本里。
2 手动配置多个Bonds
针对那些网络初始化脚本缺少对多bonds配置支持的系统,这里介绍了通过不同的选项配置多bonding设备的方法。
如果你需要配置多bonding设备,但所有设备使用同样的选项,你可能希望使用"max_bonds"模块参数,就像上文描述的一样.为了创建多个不同选项的bonding设备,需要多次加载bonding驱动。要说明的是,当前版本的sysconfig网络初始化脚本自动处理这些,如果你的发行包这些脚本,你不需要额外的操作,参看上文的"配置Bonding驱动",如果你不确定你的网络初始化脚本是否支持。
为了加载模块的多个实例,需要为每个实例指定一个不同的名字(模块加载系统需要每个加载的模块有唯一的名字,即便它们是同一个模块的不同实例)。这可以通过在/etc/modprobe.conf中指定多个bonding选项,比如:
alias bond0 bonding
options bond0 -o bond0 mode=balance-rr miimon=100
alias bond1 bonding
options bond1 -o bond1 mode=balance-alb miimon=50
这将会两次加载bonding模块。第一个实例命名为"bond0",将会以balance-rr模式创建bond0设备,同时使用参数miimon为100。
第二个实例命名为"bond1",将会以balance-alb模式创建bond1设备,同时使用参数miimon为50。
在某些情况下(通常是较老的发行包),上述参数不能工作,第二个bonding实例不会用到它的选项。在这种情况下,第二个选项可以用如下的选项替换:
install bond1 /sbin/modprobe --ignore-install bonding -o bond1 \
mode=balance-alb miimon=50
这些选项可以重复任意次,以指定任意多个bonding实例,只需要为每个依次的实例指定一个唯一的名字,以替换bond1即可。
3 通过Sysfs手工配置Bonding
从版本3.0开始,Channel Bonding可以通过sysfs接口进行配置。sysfs接口允许在不卸载模块的情况下动态配置所有bonds,它也可以在运行时增加和移处bonds。Ifenslave已经不再需要了,尽管它还被支持。使用sysfs接口允许你在不重新加载模块的情况下,对多个bonds使用不同的配置;也允许你使用多个不同配置的bonds,在bonding被编译进内核的时候。
你必须mount了sysfs文件系统,以配置bonding。本文里的示例假定你标准的sysfs的mount点,即/sys,如果你的sysfs文件系统被mount在其他地方,你需要对应地调整示例里的路径。
创建和销毁Bonds
增加一个新的bond(foo):
# echo +foo /sys/class/net/bonding_masters
移除一个已存在的bond(bar):
# echo -bar /sys/class/net/bonding_masters
显示所有存在的bonds:
# cat /sys/class/net/bonding_masters
注意:由于sysfs文件的4K大小限制,如果你好多bonds,这个列表可能被截断。这在通常的情况下并不常见。
增加和移除Slaves
通过使用文件/sys/class/net//bonding/slaves,我们可以把网络接口从属于某个bond,这个文件的语义和bonding_masters文件是完全相同的。
把eth0加入bond(bond0):
# ifconfig bond0 up
# echo +eth0 /sys/class/net/bond0/bonding/slaves
从bond(bond0)里移除eth0:
# echo -eth0 /sys/class/net/bond0/bonding/slaves
注意:bond必须在slave加入之前启动,所有slave必须在bond接口断开前移除。
当一个网络接口加入某个bond,sysfs文件系统里会在两者间创建符号链接,在这时,你可以看到/sys/class/net/bond0/slave_eth0指向/sys/class/net/eth0,而/sys/class/net/eth0/master指向/sys/class/net/bond0。
这意味着你可以通过查看master的符号链接很快地知道一个接口有没有被加入。这样的话:
# echo -eth0 /sys/class/net/eth0/master/bonding/slaves
将会把eth0正确地从它所从属的bond上移除,而不需要指定bond接口的名字。
改变Bond的配置
每个bond可以独立地配置,通过操纵位于/sys/class/net//bonding下的文件。 这些文件的名字直接对应于本文里描述的命令行参数,除了arp_ip_target是个例外,它们总是接受同样的值。你可以直接把对应文件cat出来看当前的设置。
把bond0配置为balance-alb模式:
# ifconfig bond0 down
# echo 6 /sys/class/net/bond0/bonding/mode
- 或者 -
# echo balance-alb /sys/class/net/bond0/bonding/mode
注意:在修改模式前,请先断开bond接口。
在bond0上启用MII监控,使用1秒的时间间隔:
# echo 1000 /sys/class/net/bond0/bonding/miimon
注意:如果ARP监控被启用,当MII监控启用时它会被禁止,反之亦然。
增加ARP目的地址:
# echo +192.168.0.100 /sys/class/net/bond0/bonding/arp_ip_target
# echo +192.168.0.101 /sys/class/net/bond0/bonding/arp_ip_target
注意:最多可以指定十个目的地址。
移除ARP目的地址:
# echo -192.168.0.100 /sys/class/net/bond0/bonding/arp_ip_target
配置示例
为了生成一个简单的带两个e100设备(假定为eth0和eth1)的bond,而且希望它在重启后依然存在,你可以编辑对应的文件(/etc/init.d/boot.local or /etc/rc.d/rc.local),加入如下内容:
modprobe bonding
modprobe e100
echo balance-alb /sys/class/net/bond0/bonding/mode
ifconfig bond0 192.168.1.1 netmask 255.255.255.0 up
echo 100 /sys/class/net/bond0/bonding/miimon
echo +eth0 /sys/class/net/bond0/bonding/slaves
echo +eth1 /sys/class/net/bond0/bonding/slaves
下面增加第二个bond,带有两个e1000接口,工作于active-backup模式,使用ARP监控,把如下内容加入到你的初始化脚本里:
modprobe e1000
echo +bond1 /sys/class/net/bonding_masters
echo active-backup /sys/class/net/bond1/bonding/mode
ifconfig bond1 192.168.2.1 netmask 255.255.255.0 up
echo +192.168.2.100 /sys/class/net/bond1/bonding/arp_ip_target
echo 2000 /sys/class/net/bond1/bonding/arp_interval
echo +eth2 /sys/class/net/bond1/bonding/slaves
echo +eth3 /sys/class/net/bond1/bonding/slaves
我自己的测试:
[root@rac4 network-scripts]# echo -eth1 /sys/class/net/bond0/bonding/slaves
[root@rac4 network-scripts]# cat /proc/net/bonding/bond0
Ethernet Channel Bonding Driver: v3.2.4 (January 28, 2008)
Bonding Mode: load balancing (round-robin)
MII Status: up
MII Polling Interval (ms): 0
Up Delay (ms): 0
Down Delay (ms): 0
Slave Interface: eth0
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:50:56:8f:22:48
[root@rac4 network-scripts]# echo +eth1 /sys/class/net/bond0/bonding/slaves
[root@rac4 network-scripts]# cat /proc/net/bonding/bond0
Ethernet Channel Bonding Driver: v3.2.4 (January 28, 2008)
Bonding Mode: load balancing (round-robin)
MII Status: up
MII Polling Interval (ms): 0
Up Delay (ms): 0
Down Delay (ms): 0
Slave Interface: eth0
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:50:56:8f:22:48
Slave Interface: eth1
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:50:56:8f:7d:6f
bond yql 只是一个例子,没有相对应的配置文件
[root@rac4 network-scripts]# echo +yql /sys/class/net/bonding_masters
[root@rac4 network-scripts]# cat /sys/class/net/bonding_masters
bond0 yql
[root@rac4 network-scripts]# cat /proc/net/bonding/yql
Ethernet Channel Bonding Driver: v3.2.4 (January 28, 2008)
Bonding Mode: load balancing (round-robin)
MII Status: down
MII Polling Interval (ms): 0
Up Delay (ms): 0
Down Delay (ms): 0
4 查看Bonding配置
每个bonding设备对应于一个只读文件,存在于/proc/net/bonding目录,文件内容包括bonding配置的信息,选项以及每个slave的状态。
例如,在使用参数mode=0,miimon=1000时,加载驱动后,/proc/net/bonding/bond0的内容为:
[root@rac4 ~]# cat /proc/net/bonding/bond0
Ethernet Channel Bonding Driver: v3.2.4 (January 28, 2008)
Bonding Mode: load balancing (round-robin)
MII Status: up
MII Polling Interval (ms): 100
Up Delay (ms): 0
Down Delay (ms): 0
Slave Interface: eth0
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:50:56:8f:22:48
Slave Interface: eth1
MII Status: up
Link Failure Count: 0
Permanent HW addr: 00:50:56:8f:7d:6f
根据你配置、状态、以及bonding驱动版本的差异,上述内容的精确格式和内容有可能不同。
相关文章
- 管理系统管理Linux用户权限,实现安全可靠运行(linux用户和权限)
- 小米笔记本:发挥Linux优势(小米笔记本装linux)
- Linux启动:解压操作的步骤(linux启动解压)
- 实现基于Linux的服务脚本自动化管理(linux服务脚本)
- Linux文件系统管理之查看指南(linux文件系统查看)
- 管理Linux 下用户磁盘空间管理实践(linux用户磁盘空间)
- Linux下的权限管理指令实战篇(linux权限管理命令)
- Linux系统安装硬盘分区操作详解(linux安装硬盘分区)
- 利用Linux系统快速制作U盘启动盘(linux启动u盘制作工具)
- Linux日志服务器配置:极致安全拥有畅快稳定(linux日志服务器配置)
- Linux数据盘目录结构深度解析(linux数据盘目录)
- Linux系统U盘启动方式简介(linux的u盘启动)
- Linux环境下分区交换管理(linux交换分区)
- Linux运维日常智慧管理(linux运维日常工作)
- Linux发展史:展示不同的分支(linux的分支)
- Linux环境变量配置指南,搞定配置问题!(linux下环境变量配置)
- Linux网络流量轻松管理,轻松查看!(linux网络流量查看)
- Linux网卡驱动卸载实现万无一失(linux网卡驱动卸载)
- Linux中如何关闭中断?(linux关中断)
- 如何在Linux上完成JDK的安装和配置(linux安装配置jdk)
- 如何在Linux上安装和配置Samba文件共享服务(linux中samba)
- Linux系统下授权用户组的管理(linux授权用户组)
- Linux给出的信号:证明它的强大(linux 发 信号)
- 快速提升快速提升Linux操作系统学习技能(linux操作系统 学习)
- 探索Linux服务器日志背后的故事(查看linux服务器日志)
- Linux查看CPU内存:一个简单的指南(linux查看cpu内存)