VMWare虚拟机bridged、host-only和NAT网络模式的区别和用法

时间:2021-08-30 06:16:45

VMWare提供了三种工作模式,它们是bridged(bridged 模式)、NAT( 网络地址转换模式)和host-only(主机模式) 。

1  VMWare虚拟机bridged、host-only和NAT网络模式的区别

1.1 bridged(桥接模式)

在bridged 模式下, VMWare 虚拟出来的操作系统就像是局域网中的一*立的主机,它可以访问网内任何一台机器。在bridged模式下,你需要手工为虚拟系统配置I P 地址、子网掩码, 而且还要和宿主机器处于同一网段, 这样虚拟系统才能和宿主机器进行通信。同时,由于这个虚拟系统是局域网中的一个独立的主机系统,那么就可以手工配置它的TCP/IP配置信息,以实现通过局域网的网关或路由器访问互联网。

使用bridged 模式的虚拟系统和宿主机器的关系,就像连接在同一个Hub 上的两台电脑。想让它们相互通讯,你就需要为虚拟系统配置IP 地址和子网掩码,否则就无法通信。如果你想利用VMWare 在局域网内新建一个虚拟服务器,为局域网用户提供网络服务,就应该选择bri dged 模式。这种方式最简单,直接将虚拟网卡桥接到主机的一个物理网卡上面,和linux 下一个网卡绑定两个不同地址类似,实际上是将网卡设置为混杂模式,从而达到侦听多个I P 能力。在此模式下,虚拟机内部的网卡(例如linux下的eth0)直接连到了主机物理网卡所在的网络上,可以想象为虚拟机和主机处于对等的地位,在网络关系上是平等的,没有谁在谁后面的问题。

优先考虑使用bridged 模式的情况是:在局域网中有1 个以上的IP地址可以*分配使用。

1.2 N AT( 网络地址转换模式)

使用NAT 模式,就是让虚拟系统借助NAT( 网络地址转换)功能,通过宿主机器所在的网络来访问公网。也就是说,使用NAT模式可以实现在虚拟系统里访问互联网。NAT 模式下的虚拟系统的TCP/IP 配置信息是由VMnet8(NAT)虚拟网络的DHCP 服务器提供的,无法进行手工修改, 因此虚拟系统也就无法和本局域网中的其他真实主机进行通讯。采用NAT 模式最大的优势是虚拟系统接入互联网非常简单,你不需要进行任何其他的配置,只需要宿主机器能访问互联网即可;VMware的虚拟DHCP 服务器给虚拟机里面的机器分配IP地址。

这种方式也可以实现主机与虚拟机中的机器双向访问。但网络内其他机器不能访问虚拟机中的机器, 虚拟机中的机器通过主机用NAT 协议访问网络内其他机器。如果你想利用VMWare 安装一个新的虚拟系统,在虚拟系统中不用进行任何手工配置就能直接访问互联网,建议你采用NAT 模式。这种方式下主机内部出现了一个虚拟的网卡vmnet8 (默认情况下) ,这里的vmnet8 就相当于连接到内网的网卡,而虚拟机本身则相当于运行在内网上的机器,虚拟机内的网卡( eth0 ) 则独立于vmnet。你会发现在这种方式下, vmware 自带的dhcp 会默认地加载到vmnet8 界面上,这样虚拟机就可以使用dhcp 服务。更为重要的是,vmware 自带了nat 服务,提供了从vmnet8 到外网的地址转换, 所以这种情况是一个实实在在的nat 服务器在运行,只不过是供虚拟机用的。

优先考虑使用N AT( 网络地址转换模式)的情况是:只有1 个外网的IP地址可以使用。

1.3 host-only(主机模式)

在某些特殊的网络调试环境中, 要求将真实环境和虚拟环境隔离开,这时你就可采用host-only 模式。在host-only 模式中, 所有的虚拟系统是可以相互通信的, 但虚拟系统和真实的网络是被隔离开的。

提示:在host-only 模式下,虚拟系统和宿主机器系统是可以相互通信的,相当于这两台机器通过双绞线互连。

在host-only 模式下,虚拟系统的TCP/IP 配置信息(如IP 地址、网关地址、DNS 服务器等),都是由VMnet1 (host-only)虚拟网络的 DHCP 服务器来动态分配的。如果你想利用VMWare 创建一个与网内其他机器相隔离的虚拟系统,进行某些特殊的网络调试工作,可以选择host-only 模式。和nat 唯一的不同的是,此种方式下,没有地址转换服务,因此,默认认情况下, 虚拟机只能到主机访问,这也是hostonly的名字的意义。

默认情况下,也会有一个dhcp 服务加载到vmnet1上。这样连接到vmnet1 上的虚拟机仍然可以设置成dhcp ,方便系统的配置。

在VMware Host only 这种工作方式下, Guest 由DHCP 服务器分配I P 地址。但是在Guest 机器上并不能Ping 通Host 的IP。这种方式看起来是很像NAT 方式,但是在这种方式下Guest只能和Host 之间通信,而不能同在局域网的计算机进行通信,除非在Host上做转发或路由。

优先考虑使用host-only 模式的情况是:VMWare中的机器与网内其他机器相隔离。

2  设置VMware中的机器使用这三种网络连接上网
2.1 bridge模式

默认使用VMware的vmnet0

将虚拟机的Ip 设置为与主机同网段未使用的IP地址,其余与主机相同;例如主机ip是192.168.2 .46,设置虚拟机ip为192.168.2.254。netmask, broadcast, gateway, dns 都与主机相同即可实现,可以实现虚拟机<----->主机 虚拟机<----->互联网通信。

2.2 NAT模式

默认使用VMware的vmnet8

默认的状态下使用的是VMware的虚拟DHCP为其设置IP地址 。只要物理机能连通网络, 虚拟机也就可以连通的 。

手动设置静态IP: 参考 待写

2.3 host-only 模式

默认使用VMware的vmnet1

默认使用的是VMware的虚拟DHCP,组成与独立的与物理网络相隔离的虚拟网络,但其是可以和宿主机器通信。

host-only 这种模式下是独立主机的模式,意思是不可以和外界通信的。但是我们可以这样理解,这种模式使用的是vmnet1,也就是一台虚拟的交换机。不能上网的原因分析:虚拟机本身是根据自身的DHCP 分配的IP , 本身和物理机不是一个段内的。

可以这样设置上网:

1 、在物理主机的本地连接设置对vmnet1 的共享(一定要是vmnet1) ,这样vmnet1 连接的IP 也就和我们平时物理机的共享连接是一样;

2 、手动设置与物理机相同段内的IP , 与相同的DNS 解析。