在Linux 中,如何配置网桥?如何配置虚拟网络?

本章主要学习的是linux中如何设置网桥和虚拟网络的配置

一、网桥的配置

在Linux系统中配置一个新的网桥主要涉及以下几个步骤

  1. yum仓库做准备,安装组件epel-release
c 复制代码
sudo yum -y install epel-release
  1. yum仓库中安装bridge-utils
c 复制代码
 cd /etc/yum.repos.d/
 sudo yum -y install bridge-utils
  1. 查看网桥信息
c 复制代码
 brctl show

如图:

  1. 创建网桥
c 复制代码
brctl addbr f1br1

其中f1br1是网桥名,可自己定义

  1. 启用或配置

编辑网桥的配置文件,在/etc/sysconfig/network-scripts/目录下创建一个类似于ifcfg-f1br1的文件,如果你使用的是Systemd-networkd,则是在/etc/systemd/network/目录下创建对应的netdevetwork单元文件

System V初始化脚本风格

c 复制代码
echo -e "DEVICE=f1br1\nBOOTPROTO=dhcp\nONBOOT=yes" | sudo tee /etc/sysconfig/network-scripts/ifcfg-f1br1

或者静态配置IP地址

c 复制代码
echo -e "DEVICE=f1br1\nIPADDR=192.168.1.10\nNETMASK=255.255.255.0\nGATEWAY=192.168.1.1\nDNS1=8.8.8.8\nONBOOT=yes" | sudo tee /etc/sysconfig/network-scripts/ifcfg-f1br1
  1. 创建/etc/systemd/network/10-f1br1.netdev

这里我使用的echo -e 命令,也可以使用vim编辑器编辑10-f1br1.netdev的内容,

c 复制代码
mkdir /etc/systemd/network/10-f1br1.netdev -p
 echo -e "[NetDev]\nName=f1br1\nKind=bridge" | sudo tee /etc/systemd/network/10-f1br1.netdev

文件10-f1br1.netdev的内容为:

[NetDev]

Name=br0

Kind=bridge

  1. 接着创建/etc/systemd/network/20-br0.network文件
c 复制代码
mkdir /etc/systemd/network/20-f1br1.network -p
echo -e "[Match]\nName=f1br1\n[Network]\nDhcp=yes"| tee /etc/systemd/network/20-f1br1.network

文件20-br0.network的内容为:

[Match]

Name=br0

[Network]

DHCP=yes # 如果使用DHCP动态获取IP
#或者配置静态IP

Address=192.168.1.10/24

Gateway=192.168.1.1

DNS=8.8.8.8
[Route]

如有必要,可在此添加默认路由或其他路由信息

  1. 查看网卡配置信息并且将物理网卡加入网桥

查看物理网卡

c 复制代码
ip addr show

如:

添加至网桥

c 复制代码
 brctl addif f1br1 ens160
  1. 重启服务
c 复制代码
 systemctl restart network-online.target 
 systemctl restart systemd-network-generator.service 
  1. 检查是否配置成功
c 复制代码
 ip link show f1br1

如:


二、虚拟网络的创建

在Linux中,使用KVM和libvirt管理虚拟机的情况下,定义一个新的虚拟网络通常涉及到创建一个XML配置文件,然后使用virsh命令行工具来定义和管理网络。

  1. 创建XML配置文件

创建一个XML文件,例如 f1br1.xml,并编写虚拟网络的配置。

以下是一个基本的内部网络(私有网络)的示例配置:

xml 复制代码
<network>
  <name>f1br1</name>
  <uuid>YOUR_NETWORK_UUID</uuid>
  <forward mode='nat'>
    <nat>
      <port start='1024' end='65535'/>
    </nat>
  </forward>
  <bridge name='f1br11' stp='on' delay='0'/>
  <ip address='192.168.122.1' netmask='255.255.255.0'>
    <dhcp>
      <range start='192.168.122.2' end='192.168.122.254'/>
    </dhcp>
  </ip>
</network>

创建了一个带有NAT转发模式的网络,网络桥名为virbr1,并设置了DHCP服务分配的IP地址范围。

  1. 定义虚拟网络

使用virsh net-define命令加载配置文件来定义网络:

bash 复制代码
sudo virsh net-define f1br1.xml
  1. 启动虚拟网络
bash 复制代码
sudo virsh net-start f1br1.xml
  1. 设置网络开机自启动
bash 复制代码
sudo virsh net-autostart f1br1
  1. 查看虚拟网络状态
bash 复制代码
virsh net-list 

这篇文章中,可能会在实际有些小差错,有哪些不好的地方,欢迎来评论区告知!

谢谢大家的观看❤️❤️🎉🎉

一起加油学习吧!🌈🌈

相关推荐
7yewh8 分钟前
嵌入式Linux QT+OpenCV基于人脸识别的考勤系统 项目
linux·开发语言·arm开发·驱动开发·qt·opencv·嵌入式linux
Arenaschi12 分钟前
在Tomcat中部署应用时,如何通过域名访问而不加端口号
运维·服务器
小张认为的测试12 分钟前
Linux性能监控命令_nmon 安装与使用以及生成分析Excel图表
linux·服务器·测试工具·自动化·php·excel·压力测试
waicsdn_haha20 分钟前
Java/JDK下载、安装及环境配置超详细教程【Windows10、macOS和Linux图文详解】
java·运维·服务器·开发语言·windows·后端·jdk
打鱼又晒网21 分钟前
linux网络套接字 | 深度解析守护进程 | 实现tcp服务守护进程化
linux·网络协议·计算机网络·tcp
m0_7482400223 分钟前
Chromium 中chrome.webRequest扩展接口定义c++
网络·c++·chrome
終不似少年遊*31 分钟前
华为云计算HCIE笔记05
网络·华为云·云计算·学习笔记·hcie·认证·hcs
良许Linux34 分钟前
0.96寸OLED显示屏详解
linux·服务器·后端·互联网
蜜獾云1 小时前
docker 安装雷池WAF防火墙 守护Web服务器
linux·运维·服务器·网络·网络安全·docker·容器
小屁不止是运维1 小时前
麒麟操作系统服务架构保姆级教程(五)NGINX中间件详解
linux·运维·服务器·nginx·中间件·架构