linux虚拟机3种网络模式

Posted 关灯吃面

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux虚拟机3种网络模式相关的知识,希望对你有一定的参考价值。

虚拟机网络模式

无论是vmware,virtual box,virtual pc等虚拟机软件,一般来说,虚拟机有三种网络模式:

1.桥接

2.NAT

3.Host-Only

 

一、Brigde——桥接:默认使用VMnet0 

桥接网络是指本地物理网卡和虚拟网卡通过VMnet0虚拟交换机进行桥接,物理网卡和虚拟网卡在拓扑图上处于同等地位,那么物理网卡和虚拟网卡就相当于处于同一个网段,虚拟交换机就相当于一台现实网络中的交换机,所以两个网卡的IP地址也要设置为同一网段。 

所以当我们要在局域网使用虚拟机,对局域网其他pc提供服务时,例如提供ftp,提供ssh,提供http服务,那么就要选择桥接模式。 

例如大学宿舍里有一个路由器,宿舍里四个人连接这个路由器,路由器的wanip就不理会了,这个ip是动态获取的,而lanip默认是192.168.1.1,子网掩码是255.255.255.0。而其他四个人是自动获取ip,假设四个人的ip是:

A:192.168.1.100/255.255.255.0,

B:192.168.1.101/255.255.255.0,

C:192.168.1.102/255.255.255.0,

D:192.168.1.103/255.255.255.0

 

那么虚拟机的ip可以设置的ip地址是

192.168.1.2-192.168.1.99,

192.168.1.104-192.168.1.254

(网络地址全0和全1的除外,再除去ABCD四个人的ip地址) 

 

那么虚拟机的ip地址可以设置为192.168.1.98/255.255.255.0,设置了这个ip地址,ABCD这四个人就可以通过192.168.1.98访问虚拟机了,如果虚拟机需要上外网,那么还需要配置虚拟机的路由地址,就是192.168.1.1了,这样,虚拟机就可以上外网了,但是,上网我们一般是通过域名去访问外网的,所以我们还需要为虚拟机配置一个dns服务器,我们可以简单点,把dns服务器地址配置为google的dns服务器:8.8.8.8,到此,虚拟机就可以上网了。

 

联网方式特点: 

这一种联网方式最简单,在局域网内,你的主机是怎么联网的,你在虚拟机里就怎么连网。把虚拟机看成局域网内的另一台电脑就行了。

桥接模式虚拟机都可以上外网,多个虚拟机之间可以互相访问。
提示:主机网卡处在一个可以访问Internet的局域网中,虚拟机才能通过Bridge访问Internet。 

 

二、NAT——网络地址转换 :默认使用VMnet8 

NAT模式中,就是让虚拟机借助NAT(网络地址转换)功能,通过宿主机器所在的网络来访问公网。NAT模式中,虚拟机的网卡和物理网卡的网络,不在同一个网络,虚拟机的网卡,是在vmware提供的一个虚拟网络。 

NAT和桥接的比较:

(1) NAT模式和桥接模式虚拟机都可以上外网。

(2) 由于NAT的网络在vmware提供的一个虚拟网络里,所以局域网其他主机是无法访问虚拟机的,而宿主机可以访问虚拟机,虚拟机可以访问局域网的所有主机,因为真实的局域网相对于NAT的虚拟网络,就是NAT的虚拟网络的外网。

(3) 桥接模式下,多个虚拟机之间可以互相访问;NAT模式下,多个虚拟机之间也可以相互访问

 

如果你建一个虚拟机,只是给自己用,不需要给局域网其他人用,那么可以选择NAT,毕竟NAT模式下的虚拟系统的TCP/IP配置信息是由VMnet8(NAT)虚拟网络的DHCP服务器提供的,只要虚拟机的网路配置是DHCP,那么你不需要进行任何其他的配置,只需要宿主机器能访问互联网即可,就可以让虚拟机联网了。

 

例如你想建多个虚拟机集群,作为测试使用,而宿主机可能是一个笔记本,ip不固定。这种应用场景,我们需要采用nat模式了,但是我们要考虑一个问题,虚拟机之间是需要互访的,默认采用dhcp,虚拟机的ip每次重启,ip都是不固定的,所以我们需要手工设置虚拟机的ip地址。 

但是我们对虚拟机网卡所在的虚拟网络的信息还一无所知,例如虚拟机网络的路由地址,子网掩码,所以我们需要先查下nat虚拟网络的信息。 

使用vmware,在Edit->Virtual Network Editor中配置好虚拟网络信息后看到下图所示,注意VMnet8,VMnet8相当于是本机的一个路由,虚拟机设置NAT后就通过这个路由进行上网的,可以查看其网络地址,路由地址,子网掩码。

 

联网方式: 
方法1、动态IP地址。
主机是静态IP或动态IP,都无所谓,将虚拟机设置成使用DHCP方式上网,Windows下选择“自动获取IP“,linux下开启DHCP服务即可。(这种方法最简单,不用过多的设置,但要在VMware中进行“编辑→虚拟网络设置”,将NAT和DHCP都开启了。一般NAT默认开启,DHCP默认关闭)    
方法2、静态IP地址。
如果不想使用DHCP,也可以手动设置: 
IP设置与vmnet1同网段,网关设置成vmnet8的网关(在“虚拟网络设置”里的Net选项卡里能找到Gateway)通常是xxx.xxx.xxx.2。 
子网掩码设置与VMnet8相同(设置好IP地址后,子网掩码自动生成),DNS设置与主机相同。 

例如:主机IP是10.70.54.31,设置虚拟机IP为10.70.54.22。Netmask,Gateway,DNS都与主机相同即可实现。

  虚拟机<--->主机 虚拟机<---->互联网 通信。 

提示:使用NAT技术,主机能上网,虚拟机就可以访问Internet,多个虚拟机之间也可以相互访问,局域网其他主机是无法访问虚拟机的,而宿主机可以访问虚拟机。

 

三、Host-Only——私有网络共享主机:默认使用VMnet1  

提供的是主机和虚拟机之间的网络互访。只想让虚拟机和主机之间有数据交换,而不想让虚拟机访问Internet,就要采用这个设置了。 
Host-only的条件下,VMWare在真正的Windows系统中,建立一块网卡。这块网卡可以在网络连接中看到,一般是VMnet1,这块网卡的作用就是使Windows看到虚拟机的IP。

联网方法: 
方法1、动态IP地址。 
像上面那样开启DHCP后,虚拟机直接自动获取IP地址和DNS。就可以和主机相连了。当然,还要进行一些局域网共享的操作,这里不再赘述。 
方法2、静态IP地址。 
也可以手动设置,将虚拟机IP设置与VMnet1同网段,网关设置成VMnet1的网关相同,其余设置与VMnet1相同,DNS设置与主机相同。 
例如:VMnet1 IP:172.16.249.1 Gateway :172.16.249.2    
那么虚拟机 IP:172.16.249.100 Gateway: 172.16.249.2    
  虚拟机<--->主机 可以通信 
  虚拟机<--->互联网 无法通信 
提示:Host-only技术只用于主机和虚拟机互访,于访问internet无关。

 

 

综述

在VMware的3中网络模式中,NAT模式是最简单的,基本不需要手动配置IP地址等相关参数。至于桥接模式则需要额外的IP地址,如果是在内网环境中还很容易,如果是ADSL宽带就比较麻烦了,ISP一般是不会大方的多提供一个公网IP的。

 

参考资料:

http://blog.csdn.net/u013982161/article/details/52504360 
https://www.cnblogs.com/skorzeny/p/6864485.html
http://blog.sina.com.cn/s/blog_60c00c780100xy0u.html

 

 

 

 

以上是关于linux虚拟机3种网络模式的主要内容,如果未能解决你的问题,请参考以下文章

linux虚拟机中和主机三种网络连接方式的区别

虚拟机 linux 网络连接的三种方式

linux三种网络模式

Windows和linux虚拟机之间联网实现SSH远程连接以及VMware的3种网络模式[NAT桥接和Host-only]

Linux虚拟机的三种网络连接方式

Linux基础——三种网络模式解析