欢迎来到站长天空!

其它服务器

当前位置: 主页 > 服务器 > 其它服务器

kvm虚拟机配置NAT端口转发的实现方法

时间:2025-12-22 09:30:05|栏目:其它服务器|点击:

目录
  • 1. 概述
  • 2. iptables创建规则
  • 3. 查看和清除
  • 4. 一些别的问题

1. 概述

在内网一台物理机部署了kvm虚拟化环境。为了避免虚拟机的IP地址和内网网段冲突,kvm采用的是NAT模式,而非桥接模式。因此在本地访问kvm虚拟机时,必须用物理机来实现转发,才能登录到虚拟机。而kvm的转发,需要使用Linux的iptables工具来实现

2. iptables创建规则

先创建虚拟机,比如创建一台虚拟机node98,其ip地址是192.168.80.98,我想在本地访问node98的22端口,是无法实现的。所以需要进行以下操作:

iptables -t nat -A PREROUTING -p tcp --destination 192.168.212.93 --dport 2298 -j DNAT --to-destination 192.168.80.98:22
iptables -t nat -A POSTROUTING -p tcp --dport 22 -d 192.168.80.98 -j SNAT --to 192.168.212.93
iptables -D FORWARD 5 -t filter
iptables -D FORWARD 4 -t filter

上述使用iptables配置了物理机192.168.212.93到其内部kvm虚拟机node98的22端口转发。需要注意的是:

iptables -D FORWARD 5 -t filter
iptables -D FORWARD 4 -t filter

这两条需要操作,否则转发不成功,登录失败

3. 查看和清除

物理机创建的虚拟机多了,端口转发规则多了起来。使用以下命令查看当前的转发规则

iptables -nL -v --line-numbers -t nat

会在Chain PREROUTING Chain POSTROUTING 看到对应的条目。

清除当前规则:

iptables -t nat -F PREROUTING
iptables -t nat -F POSTROUTING

4. 一些别的问题

  • 清理规则后,建议重启libvirtd和虚拟机,否则会存在虚拟机无法ping通外网的情况
  • 每次添加转发规则时,应该都需要执行iptables -D FORWARD的操作,否则无法登录
  • 如果在虚拟机部署了Java开发环境,使用vscode远程开发时,配置Tomcat的端口转发,不需要在物理机和虚拟机再操作,一切由vscode自行完成

上一篇:Containerd容器运行yum安装与二进制安装

栏    目:其它服务器

下一篇:Docker MySQL无法被宿主机访问的问题解决

本文标题:kvm虚拟机配置NAT端口转发的实现方法

本文地址:https://zz.feitang.co/server/32641.html

广告投放 | 联系我们 | 版权申明

申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:257218569 | 邮箱:257218569@qq.com

Copyright © 2018-2025 站长天空 版权所有 Powered by EyouCms冀ICP备14023439号