KVM中使用桥接模式.运维就业技术教程

在KVM中使用桥接模式可以让虚拟机直接接入物理网络,使其成为局域网中的独立节点。以下是配置和使用桥接模式的详细指南:


一、桥接模式原理

  • 作用 : 虚拟机通过宿主机的网桥(如virbr0)直接与物理交换机/路由器通信,获得与宿主机相同的网段IP。
  • 特点 :
    • 虚拟机拥有独立IP,可被局域网内其他设备直接访问。
    • 无需NAT转换,网络性能更高。
    • 需确保宿主机网桥已正确配置。

二、配置步骤

1. 创建网桥接口

大多数Linux发行版默认包含virbr0网桥(由libvirt自动管理)。若需自定义网桥:

bash 复制代码
# 查看现有网桥
virsh list --all | grep virbr0

# 手动创建网桥(假设eth0为宿主机主网卡)
sudo brctl addbr mybr0          # 创建新网桥mybr0
sudo brctl addif mybr0 eth0     # 将eth0加入网桥

# 启用网桥并禁用原网卡IP(可选)
sudo ifconfig mybr0 up          # 激活网桥
sudo ifconfig eth0 0.0.0.0      # 清空eth0 IP(推荐)
2. 配置虚拟机使用桥接

编辑虚拟机XML配置(以virsh edit <vm_name>为例):

xml 复制代码
<interface type='bridge'>
  <mac address='52:54:00:f1:84:5b'/>
  <source bridge='mybr0'/>       <!-- 指向自定义网桥 -->
  <model type='virtio'/>
</interface>
3. 虚拟机内部网络配置
  • 自动获取IP : 启用DHCP客户端(如dhclient)。
  • 静态IP配置: 手动设置与宿主机同网段的IP,网关和DNS需一致。

三、关键注意事项

  1. 网桥必须存在

    • 若使用默认virbr0,确保其已启动:

      bash 复制代码
      virsh net-start default && virsh net-autostart default
    • 自定义网桥需提前创建(见步骤1)。

  2. 避免IP冲突

    • 关闭宿主机上的重复IP分配服务(如NetworkManager的DHCP功能)。
    • 虚拟机建议使用DHCP动态分配。
  3. 防火墙配置

    • 开放宿主机网桥的流量:

      bash 复制代码
      sudo firewall-cmd --permanent --zone=public --add-interface=mybr0
      sudo firewall-cmd --reload
  4. 多网卡共存场景

    • 若虚拟机有多个接口,需明确优先级:
      • 优先使用桥接接口作为默认路由。
      • 删除冗余的NAT接口(type='network')以避免路由混乱。

四、故障排查

  1. 虚拟机无IP地址

    • 检查虚拟机是否启用了DHCP客户端。
    • 确认宿主机网桥的DHCP服务正常运行(如dnsmasq)。
  2. 无法访问外网

    • 检查宿主机默认路由是否正确。
    • 确保虚拟机的默认路由指向网桥网关。
  3. 主机与虚拟机通信异常

    • 使用ping测试双方互通性。
    • 检查中间网络设备(如交换机)的MAC地址表。

五、示例完整配置

xml 复制代码
<devices>
  <emulator>/usr/bin/qemu-system-x86_64</emulator>
  <interface type='bridge'>
    <mac address='52:54:00:f1:84:5b'/>
    <source bridge='virbr0'/>
    <model type='virtio'/>
  </interface>
</devices>

通过以上配置,虚拟机将直接接入物理网络,实现与局域网设备的无缝通信。

相关推荐
MoloXuanhe19 分钟前
[TryHackMe]Wordpress: CVE-2021-29447(wp漏洞利用-SSRF+WpGetShell)
运维·网络·安全·tryhackme·thm
wanhengidc32 分钟前
网页版的云手机都有哪些优势?
运维·网络·安全·游戏·智能手机
2418ly1 小时前
docker常用命令
运维·docker·容器
Nazi63 小时前
sealos部署k8s
运维·kubernetes·k8s
白鹭3 小时前
MySQL主从复制进阶(GTID复制,半同步复制)
linux·运维·数据库·mysql·集群
Dobby_054 小时前
【Linux】网络安全管理:SELinux 和 防火墙联合使用 | Redhat
linux·运维·云原生·防火墙·selinux
cetcht88884 小时前
安徽某能源企业积极推进运维智能化转型,引入高压配电房机器人巡检系统
运维·人工智能·物联网·机器人·能源
wheeldown4 小时前
【Linux】Linux进程状态和僵尸进程:一篇看懂“进程在忙啥”
linux·运维·服务器·进程
半桔4 小时前
【Linux手册】动静态库:从原理到制作
linux·运维·服务器·动态库
z202305085 小时前
Linux之块设备的多队列的实现机制
linux·运维·服务器