物理机内外网原理
物理机通常有2个网卡,一个网卡连接内网、一个网卡连接外网,比如连接无线或者优先,除了内网网段,其它网段设置默认路由为外网网关。
虚拟机内外网原理
虚拟机内外网同物理机内外网类似,需要虚拟出2个网卡,然后通过虚拟交换机(通常说的桥接)与物理机分别共享内外网网络。
实践
linux中的网卡名称通常如enp7s0,全称是Ethernet pci7 socket0,
- Ethernet,以太网
- pci,外设组件互连标准(Peripheral Component Interconnect),或称个人电脑接口(Personal Computer Interface),实际应用中简称为PCI,是一种连接电脑主板和外部设备的总线标准。
- socket,可以理解为插槽。
物理机编辑配置文件
物理机用的debian,我用了,最原始的方式,编辑/etc/network/interfaces
,修改后,systemctl restart networking
,为了防止与NetworkManager冲突,停止systemctl stop NetworkManager
,然后禁止自动重启systemctl disable NetworkManager
,
root@pve1:~# cat /etc/network/interfaces
# 开机自启lo网卡
auto lo
# iface是interface的缩写
iface lo inet loopback
# 手动配置enp7s0 网卡
iface enp7s0 inet manual
# 设置虚拟交换机,开机自启,
auto vmbr0
# 设置静态ip,静态ip通常用于内网
iface vmbr0 inet static
# 设置ip及子网掩码
address ip/16
# 网关
gateway gateway1
# 桥接端口,使用物理网卡
bridge-ports enp7s0
bridge-stp off
bridge-fd 0
# 设置某些网段,使用指定指定网关
up ip route add 172.29.0.0/16 via gateway1 dev vmbr0
# 设置外网网卡
iface enp8s0 inet manual
# 虚拟外网交换机
auto vmbr1
# ip动态获取
iface vmbr1 inet dhcp
# 注意,必须显式设置网关,当作默认路由,否则无法访问外网,比如curl baidu不通
gateway gateway1
# 桥接使用物理网卡
bridge-ports enp8s0
bridge-stp off
bridge-fd 0
source /etc/network/interfaces.d/*
虚拟机使用NetworkManager
虚拟机用的pve(Proxmox Virtual Environment),在管理界面,虚拟出2个网卡,分别使用物理机的交换机,然后登陆虚拟机Ubuntu修改网络(使用NetworkManager工具),命令行下执行nmtui
,拉起图形客户端。

修改后,执行nmcli connection reload
,nmcli connection up device
使之生效。
总结
- 内外网的原理,是有两块网卡, 一块内网网卡、一块外网网卡,可将外网网关设置为默认路由,如有其它网段走内网,可在内网网卡部分设置
- 虚拟机与物理机共享内外网的原理是,虚拟出2个网卡,分别设置内网ip(与物理机同一个网段)和外网ip(自动获取ip,当作默认路由)