返回顶部
首页 > 资讯 > 服务器 >kvm虚拟机配置NAT端口转发的实现方法
  • 408
分享到

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

2024-04-02 19:04:59 408人浏览 独家记忆
摘要

目录1. 概述2. iptables创建规则3. 查看和清除4. 一些别的问题1. 概述 在内网一台物理机部署了kvm虚拟化环境。为了避免虚拟机的IP地址和内网网段冲突,kvm采用的

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自行完成

到此这篇关于kvm虚拟机配置NAT端口转发的文章就介绍到这了,更多相关kvm NAT端口转发内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

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

本文链接: https://lsjlt.com/news/152220.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作