PVE网络NAT配置+外部访问内部虚拟机服务配置

最近买了一个mini主机,放在公司,装了PVE系统,辅助开发,打包和学习使用。新电脑上网需要向公司运维备案电脑的mac地址,于是就向运维报备了MAC地址。默认PVE是只创建了一个网桥(交换机),内部的虚拟机相当于直连了公司的网络,这样每创建一个虚拟机都要找网管去备案,还要占用公司一个固定的ip地址资源,这样还是挺麻烦的。但是它的优势也非常明显,它与我的工作主机同在一个局域网,我访问虚拟机的时候就非常方便。

本着多一事不如少一事的原则,pve内部使用nat方式更好一些,这样我可以随意的创建和删除虚拟机,但就是工作主机访问内部虚拟机会麻烦一点,需要转一个端口转发,完整的配置如下:

PVE的网络配置:

  • ip地址: 192.168.32.250
  • 子网掩码:255.255.255.0
  • 网关: 192.168.32.254

虚拟机内部网络:

10.10.10.0/24

工作主机:

192.168.32.109

bash 复制代码
auto lo
iface lo inet loopback

iface enp2s0 inet manual

#系统默认创建的交换机,保持不动
auto vmbr0
iface vmbr0 inet static
        address 192.168.32.250/24
        gateway 192.168.32.254
        bridge-ports enp2s0 #该虚拟交换机与真实的物理网口进行绑定
        bridge-stp off
        bridge-fd 0

#再创建一个虚拟路由器(网关)
auto vmbr1          
iface vmbr1 inet static
        address  10.10.10.1
        netmask  255.255.255.0
        bridge-ports none
        bridge-stp off
        bridge-fd 0
        post-up echo 1 > /proc/sys/net/ipv4/ip_forward #打开IP转发
        post-up echo 1 > /proc/sys/net/ipv4/conf/eno1/proxy_arp #代理 ARP 允许一个主机在一个子网上代表另一个主机响应 ARP 请求,ARP 是一种用于将 IP 地址解析为 MAC(Media Access Control)地址的协议
        #转发IPv4流量到虚拟机,使虚拟机与外网联通。
        #SNAT 内网转外网,当内部虚拟器需要访问外网时走这条规则
        post-up iptables -t nat -A POSTROUTING -s '10.10.10.0/24' -o vmbr0 -j MASQUERADE # -A添加规则
        post-down iptables -t nat -D POSTROUTING -s '10.10.10.0/24' -o vmbr0 -j MASQUERADE # -D删除规则
        #DNAT 外网转内网,当外部访问内部虚拟机的服务器时走这条规则
        post-up iptables -t nat -A PREROUTING -i vmbr0 -d 192.168.32.250 -p tcp --dport 8080 -j DNAT --to 10.10.10.100:80 # -A添加规则
        post-down iptables -t nat -D PREROUTING -i vmbr0 -d 192.168.32.250 -p tcp --dport 8080 -j DNAT --to 10.10.10.100:80 # -D删除规则

经过上面的配置,我就可以\

  • 在虚拟机里访问外部网络
  • 在ip是192.168.32.109的工作主机上通过http://192.168.32.250:8080 访问pve内部虚拟机10.10.10.100:80上面的服务了
相关推荐
AOwhisky12 小时前
MySQL 学习笔记(第三期):SQL 语言之数据操作与单表查询
linux·运维·笔记·sql·学习·mysql·云计算
技术不好的崎鸣同学12 小时前
x64汇编之前篇内容复习(上)
运维·服务器
tellmewhoisi13 小时前
linux 基础知识(文件权限相关)
linux·运维·服务器
醇氧13 小时前
【Linux 】sudo、sudo -i、su、su - 完整区别总结
linux·运维·服务器
我先去打把游戏先14 小时前
VMware NAT 模式 Ubuntu 虚拟机「宿主机能上网、虚拟机 ping 不通外网 + apt 更新卡死」全故障复盘
linux·运维·vscode·单片机·嵌入式硬件·ubuntu·keil5
开压路机14 小时前
基础IO
linux·运维·服务器
呉師傅14 小时前
EPSON爱普生 L3118打印头【喷头】清洗方法
运维·服务器·网络·学习·电脑
我命由我1234515 小时前
Excel - Excel 单元格格式同时设置日期时间
运维·学习·职场和发展·excel·求职招聘·职场发展·学习方法
Cx330❀15 小时前
【Linux网络】一文吃透 TCP Socket 编程
linux·运维·服务器·开发语言·网络·tcp/ip
zizle_lin15 小时前
WSL初始化Ubuntu的使用
linux·运维·ubuntu·wsl