【Linux】Bonding配置,管理

简介:
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驱动版本的差异,上述内容的精确格式和内容有可能不同。
相关实践学习
部署高可用架构
本场景主要介绍如何使用云服务器ECS、负载均衡SLB、云数据库RDS和数据传输服务产品来部署多可用区高可用架构。
负载均衡入门与产品使用指南
负载均衡(Server Load Balancer)是对多台云服务器进行流量分发的负载均衡服务,可以通过流量分发扩展应用系统对外的服务能力,通过消除单点故障提升应用系统的可用性。 本课程主要介绍负载均衡的相关技术以及阿里云负载均衡产品的使用方法。
相关文章
|
10天前
|
安全 Ubuntu Java
Linux配置使用篇
Linux配置使用篇
|
22天前
|
存储 负载均衡 索引
linux7安装elasticsearch-7.4.0集群配置
linux7安装elasticsearch-7.4.0集群配置
109 0
|
27天前
|
监控 Linux Shell
【Shell 命令集合 网络通讯 】Linux 配置和管理网络流量的形状 shapecfg命令 使用指南
【Shell 命令集合 网络通讯 】Linux 配置和管理网络流量的形状 shapecfg命令 使用指南
38 0
|
27天前
|
网络协议 Shell Linux
【Shell 命令集合 网络通讯 】Linux 设置和配置PPP pppsetup命令 使用教程
【Shell 命令集合 网络通讯 】Linux 设置和配置PPP pppsetup命令 使用教程
34 0
|
22天前
|
存储 算法 Linux
【Linux 应用开发 共享内存】深入理解和实践 ftruncate:共享内存的有效管理
【Linux 应用开发 共享内存】深入理解和实践 ftruncate:共享内存的有效管理
54 5
|
27天前
|
存储 Shell Linux
【Shell 命令集合 系统管理 】Linux 修改用户的属性和配置 usermod命令 使用指南
【Shell 命令集合 系统管理 】Linux 修改用户的属性和配置 usermod命令 使用指南
30 1
|
27天前
|
搜索推荐 Shell Linux
【Shell 命令集合 系统管理 】Linux 管理用户配置文件 userconf命令 使用指南
【Shell 命令集合 系统管理 】Linux 管理用户配置文件 userconf命令 使用指南
32 2
|
10天前
|
网络协议 Linux
在Linux中,管理和配置网络接口
在Linux中管理网络接口涉及多个命令,如`ifconfig`(在新版本中被`ip`取代)、`ip`(用于网络设备配置)、`nmcli`(NetworkManager的CLI工具)、`nmtui`(文本界面配置)、`route/ip route`(处理路由表)、`netstat/ss`(显示网络状态)和`hostnamectl/systemctl`(主机名和服务管理)。这些命令帮助用户启动接口、设置IP地址、查看连接和路由信息。不同发行版可能有差异,建议参考相应文档。
19 4
|
17天前
|
存储 固态存储 Unix
Linux中磁盘分区和文件系统管理
在Linux系统中,磁盘是存储数据的物理设备,如HDD或SSD,以文件形式存在于`/dev`目录下,如`sda`、`sdb`等。文件系统定义了如何在磁盘上组织和访问数据,常见的Linux文件系统有ext2、ext3、ext4、xfs等。通过虚拟机软件如VMware,用户可以向Linux虚拟机添加新的硬盘。
|
20天前
|
网络协议 Linux 网络安全
Linux服务器DNS服务器配置实现bind的正向解释和反向解释
Linux服务器DNS服务器配置实现bind的正向解释和反向解释
17 0