标签:
最近折腾虚拟机,由于是在linux下进行的,而相关资料比较少,所以遇到了一些问题。
一个就是配置vmware workstation的NAT设置。因为一般来说,NAT可以共享主机的ip,从而能以主机身份访问互联网,不需要单独为虚拟机配置IP了,另外,vmware workstation中的NAT设置里是可以进行端口转发的,所以添加了端口映射后,是很容易通过宿主机的某个端口访问到虚拟机的资源。我觉得是非常实用便捷的。所以配置虚拟机首选NAT方式。我是在linux宿主机上配置一台linux虚拟机。
一个是宿主机上vmware workstation的NAT配置文件路径,一般来说位于:
|
1
|
/etc/vmware/vmnet8/nat/nat.conf |
另外一个是linux中的网络地址配置文件路径,一般位于:
|
1
|
/etc/network/interfaces |
这里,首先要配置虚拟机的IP地址。当然,配置之前要知道NAT的网关和子网掩码,这个vmware自带了一个工具:vmware-netcfg,位于vmware的安装文件夹下。默认应该在/usr/lib/vmware/bin/vmware-netcfg。使用超级用户权限打开:
|
1
|
sudo /usr/lib/vmware/bin/vmware-netcfg |

可以看到默认NAT配置的虚拟网卡为vmnet8,这里有它的网关等信息,由于我希望使用静态的ip配置,所以我取消了DHCP的自动分配。当然,这些都是可以改动的。
知道了这些信息以后,就可以配置虚拟机中的ip地址了,对应文件位于
|
1
|
/etc/network/interfaces |
默认的前两行是回环地址的配置,一般不用更改,对于下面的配置静态的ip,指定网关,子网掩码,以及dns的名字服务器。例如我的配置为
|
1
2
3
4
5
6
7
8
9
10
11
|
# The loopback network interfaceauto loiface lo inet loopback# The primary network interfaceauto eth0iface eth0 inet staticaddress 192.168.198.10netmask 255.255.255.0gateway 192.168.198.2dns-nameservers 192.168.198.2 |
这样配置完毕,重启虚拟机的网络服务
|
1
|
sudo /etc/init.d/networking restart |
这时候测试一下,应该可以访问网络了。
虚拟机可以访问外网了,那么接下来需要外网访问虚拟机的资源。比如我在虚拟机架设了一个HTTP服务器,位于虚拟机的80端口,如果我想映射到主机的100080端口。这时候需要直接编辑vmware的NAT配置文件了。上面的那个小工具已经不够用了。
|
1
|
sudo vim /etc/vmware/vmnet8/nat/nat.conf |
打开配置文件,可以看到一个配置文件。当然,这个文件的其他选项也可以根据情况编辑,端口映射的主要在
|
1
2
3
4
5
6
7
8
9
10
11
12
|
[incomingtcp]# Use these with care - anyone can enter into your VM through these...# The format and example are as follows:#<external port number> = <VM‘s IP address>:<VM‘s port number>#8080 = 172.16.3.128:8010080=192.168.198.10:80[incomingudp]# UDP port forwarding example#6000 = 172.16.3.0:6001 |
注释中已经有示例了,比如我想映射的虚拟机HTTP端口到主机的10080端口,由于HTTP协议是基于TCP协议的,所以在incomingtcp中添加一行:
|
1
|
10080=192.168.198.10:80 |
编辑完毕后,保存并重启vmware服务:
|
1
|
sudo service vmware restart |
到此就配置完毕了。如果虚拟机中80端口的服务已经开启,访问localhost:10080,可以看到对应虚拟机的资源内容
linux主机下的Vmware Workstation配置NAT设置 端口映射-Ubuntu为例
标签:
原文地址:http://www.cnblogs.com/yudar/p/4475720.html