当前位置: 首页 > news >正文

CentOS 7系统双网卡配置动态链路聚合(bond4)

一、应用场景

在机房建设时,服务器的网卡需要配置成bond4,可以使用我下面的配置文件和脚本来进行配置,简化配置流程。

bond4,即动态链路聚合,它可以将服务器上的两个物理网卡聚合为一个,两个网口逻辑成一个网口,配置一个ip地址,其中一个网口故障down掉,另一个网口仍然可以正常工作,起到一个冗余的作用,本文章只讲配置过程,大家可以搜索一下,深入学习一下链路聚合的知识。

服务器操作系统为:CentOS 7.9
CentOS 7.x应该是通用,其他LInux发行版可能需要进行调整,欢迎大家评论区交流学习。

二、详细配置

cat bond.sh
脚本中除了bond4配置外,还对服务器进行了一些简单的初始化操作,不需要可以注释掉

# 检查是否提供了 $1 参数
if [ -z "$1" ]; thenecho "错误: 你没有提供任何参数。"echo "用法: $0 <参数1>"exit 1
fi# 获取并打印 $1 的值
echo "IP is : $1"
cd /mnt/bound# 将网卡配置文件备份,将新的配置文件移动到/etc/sysconfig/network-scripts/下
ls /etc/sysconfig/network-scripts/
echo "___________________________"
mv /etc/sysconfig/network-scripts/ifcfg-ens13f0 /etc/sysconfig/network-scripts/ifcfg-ens13f0.bak
mv /etc/sysconfig/network-scripts/ifcfg-ens13f1 /etc/sysconfig/network-scripts/ifcfg-ens13f1.bak
cp ifcfg-ens13f0 /etc/sysconfig/network-scripts/ifcfg-ens13f0
cp ifcfg-ens13f1 /etc/sysconfig/network-scripts/ifcfg-ens13f1
cp ifcfg-bond4 /etc/sysconfig/network-scripts/ifcfg-bond4 sed -i "s/^IPADDR=.*/IPADDR=$1/" /etc/sysconfig/network-scripts/ifcfg-bond0 
# 如果不想输入完整的ip地址,可以将上一行的sed命令注释,将下一行的sed的注释解开
#sed -i "s/\(IPADDR=[0-9]*\.[0-9]*\.[0-9]*\.\)[0-9]*/\1$1/" /etc/sysconfig/network-scripts/ifcfg-bond0
echo "stop fw & selinux" # 禁用selinux和防火墙
sed -i 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config
setenforce 0
systemctl stop firewalld
systemctl disable firewalld
systemctl is-active firewalld# 修改root密码
echo "change passwd"
echo "mypass" | passwd --stdin root
echo# 重启网络服务,使配置生效
echo "restart network"
systemctl restart network
# 查看配置结果
echo 
ip -4 a | grep bond -A 3

cat ifcfg-ens13f0

TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="static"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="ens13f0"
DEVICE=ens13f0    # 根据实际网卡名进行修改
MASTER=bond4
SLAVE=yes
ONBOOT=yes

cat ifcfg-ens13f1

TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="static"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="ens13f1"
DEVICE=ens13f1     # 根据实际网卡名进行修改
MASTER=bond4
SLAVE=yes
ONBOOT=yes

cat ifcfg-bond4

DEVICE=bond4
TYPE=bond
BONDING_MASTER=yes
BOOTPROTO=static
ONBOOT=yes
IPADDR=192.168.3.101      # ip地址、掩码、网关修改为自己实际的ip地址、掩码、网关
NETMASK=255.255.255.0
GATEWAY=192.168.3.1
BONDING_OPTS="mode=4 miimon=100"

三、脚本用法

将bond.sh、ifcfg-ens13f0、ifcfg-ens13f1、ifcfg-bond4放在同一目录下。
对于ifcfg-ens13f0、ifcfg-ens13f1:先确认自己的服务器原本的网卡配置文件名是否为ifcfg-ens13f0和ifcfg-ens13f1,请大家根据实际情况修改为自己服务器的网卡配置文件名,并注意修改DEVICE=的参数

对于ifcfg-bond4:根据实际情况修改ip地址、掩码和网关地址

然后执行脚本:sh bond.sh IP地址
举例,比如,我想配置ip地址为 192.168.3.15,那么我的脚本执行命令为:sh bond.sh 192.168.3.15
如果你的ip地址是个c类地址,你可以将我的bond.sh脚本中的sed命令进行更换,然后脚本执行的命令就简化为:sh bond.sh 15

四、配置验证

通过查看ip的命令可以看到bond的配置结果,此时会有一个名为bond4的网卡,看配置信息是否符合预期

ip a

通过以下命令可以查看bond的详细状态

cat  /proc/net/bonding/bond4
http://www.lryc.cn/news/435033.html

相关文章:

  • ubuntu 20.04 一直卡在登录界面,即使密码正确也无法登录(失败记录)
  • 【深度学习】神经网络-怎么理解DNN、CNN、RNN?
  • 组织应在其网络安全策略中考虑MLSecOps吗?
  • Windows安装HeidiSQL教程(图文)
  • 存储课程学习笔记5_iouring的练习(io_uring,rust_echo_bench,fio)
  • 前端HTML+CSS+JS的入门学习
  • 通信电路和信道的区别与联系
  • 基于深度学习的蛋白质结构预测
  • 基于 Redis 的分布式锁实现原理及步骤
  • 21_动态规划与数据结构结合
  • React与Vue的对比
  • 精密量测软件(仿KLA免费浏览器程序ProfilmOnline)
  • Java项目: 基于SpringBoot+mybatis+maven实现的IT技术交流和分享平台(含源码+数据库+毕业论文)
  • STL02——手写简单版本的list
  • 基于SpringBoot的校园自助洗衣服务管理系统
  • 音视频入门基础:AAC专题(2)——使用FFmpeg命令生成AAC裸流文件
  • 第 6 篇 自定义 Helm Chart
  • Jenkis部署vue前端项目提示:sh: vue-cli-service: command not found
  • 中介者模式mediator
  • GO语言性能分析
  • 关于 PreparedStatement
  • 漫谈设计模式 [9]:外观模式
  • 多进程编程
  • 7-Zip压缩包如何添加密码,加密后如何取消
  • HarmonyOS---应用测试概述
  • 密码学---真题演练
  • 时间日期工具类
  • linux中vim常用命令大全
  • 计算机的错误计算(八十九)
  • 深入理解java并发编程之aqs框架