网络设置实现虚拟机系统局域网通信

简介:
最近移植工作接近尾声了,不过出了一个算是奇怪的问题。我的 Linux 系统是装在虚拟机上的,当我的程序做客户端时,主动连接 Windows 下面的服务端是没有问题的。由于我的程序时 TCP UDP 混合使用的。有时候,我的程序会当做服务端,此时, Windows 下面的 Socket 无法连接到我的程序。后来自己写了一些简单的 demo 进行测试发现,虚拟机可以主动连接局域网中的实体机,而反过来就不可以了。后来上网收集资料才发现,原来是虚拟机网络设置引起的。下面将相关的内容做个总结。

首先说说虚拟机的几种网络连接方式。我用的是 VirtualBox VmWare 其实也一样。它们提供了三种工作模式, bridged( 桥接模式 ) NAT( 网络地址转换模 ) host-only( 主机模式 )

 
1.       bridged( 桥接模式 )

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

此时,你的虚拟机和宿主机可以相互通信,就想局域网中的两台实体机一样。

     2.host-only(主机模式)

    在某些特殊的网络调试环境中,要求将真实环境和虚拟环境隔离开,这时你就可采用host-only模式。在host-only模式中,所有的虚拟系统是可以相互通信的,但虚拟系统和真实的网络是被隔离开的。在host-only模式下,虚拟系统和宿主机器系统是可以相互通信的,相当于这两台机器通过双绞线互连。但是并不能和局域网中的其他实体机进行通信(自己理解,为测试验证,因为该模式下和局域网的其他网络是隔离开来的)。
     3.NAT(网络地址转换模式)

使用NAT模式,就是让虚拟系统借助NAT(网络地址转换)功能,通过宿主机器所在的网络来访问公网。也就是说,使用NAT模式可以实现在虚拟系统里访问互联网。NAT模式下的虚拟系统的TCP/IP配置信息是由VMnet8(NAT)虚拟网络的DHCP服务器提供的,无法进行手工修改,因此虚拟系统也就无法和本局域网中的其他真实主机进行通讯。采用NAT模式最大的优势是虚拟系统接入互联网非常简单,你不需要进行任何其他的配置,只需要宿主机器能访问互联网即可。在该模式下,虚拟机可以访问宿主机和互联网,但是宿主机无法连通虚拟机。
一般安装虚拟系统时,都按默认的设置为NAT模式,因为它比较简单快速。但是我需要将虚拟机设置为局域网中一个独立的机子时,就需要设置为bridge模式。下面说说设置bridge模式的方法。由于网上很多方法是针对旧版本的VirtualBoxl,这里我用的3.0.10版的。
首先,关闭虚拟系统,在虚拟机中设置网络:
      虚拟机->设置->网络->网络连接;
      选择Bridged Adapter;
      点击有个按钮,点开,按默认选择;
      点击OK,关闭虚拟机设置;
其次,创建一个网桥:
      进入网络连接;
      选中“本地连接”和“VirtualBox Host-Only Network”;
      右键选择创建网桥;
      在新创建的网桥上点击右键->属性;
      设置网桥的网络IP地址等(和一般情况的设置一样);
      关闭网络连接;
最后,打开虚拟机系统进行网络设置,其设置和网桥一样,除 IP地址的最后一位。
 
通过上述步骤,你的虚拟机系统就像一台独立的机子一样,有自己的IP了。不仅可以上互联网,而且可以和宿主机以及局域网中的任何一台实体机进行通信了。


本文转自jazka 51CTO博客,原文链接:http://blog.51cto.com/jazka/271958,如需转载请自行联系原作者
相关文章
|
21天前
|
Ubuntu Windows
【Ubuntu/Arm】Ubuntu 系统如何链接有线网络(非虚拟机)?
【Ubuntu/Arm】Ubuntu 系统如何链接有线网络(非虚拟机)?
|
21天前
|
Ubuntu
虚拟机Ubuntu连接不了网络的解决方法
虚拟机Ubuntu连接不了网络的解决方法
|
11天前
|
存储 算法 Linux
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
【实战项目】网络编程:在Linux环境下基于opencv和socket的人脸识别系统--C++实现
32 6
|
12天前
|
存储 安全 测试技术
网络奇谭:虚拟机中的共享、桥接与Host-Only模式解析
网络奇谭:虚拟机中的共享、桥接与Host-Only模式解析
18 0
|
13天前
|
JavaScript Java 测试技术
基于Java的网络类课程思政学习系统的设计与实现(源码+lw+部署文档+讲解等)
基于Java的网络类课程思政学习系统的设计与实现(源码+lw+部署文档+讲解等)
30 0
基于Java的网络类课程思政学习系统的设计与实现(源码+lw+部署文档+讲解等)
|
14天前
|
安全 网络安全 SDN
虚拟网络设备的真正使命:实现有控制的通信
虚拟网络设备确实提供了强大的网络隔离能力🛡️,但这种隔离本身并不是最终目的。实际上,更重要的是通过这种隔离能力实现有控制的通信🎛️,以满足特定的业务需求、安全要求和性能标准。换句话说,网络隔离是手段,而有控制的通信才是目的🎯。
虚拟网络设备的真正使命:实现有控制的通信
|
16天前
|
机器学习/深度学习 人工智能 运维
构建未来:AI驱动的自适应网络安全防御系统
【4月更文挑战第7天】 在数字时代的浪潮中,网络安全已成为维系信息完整性、保障用户隐私和确保商业连续性的关键。传统的安全防御策略,受限于其静态性质和对新型威胁的响应迟缓,已难以满足日益增长的安全需求。本文将探讨如何利用人工智能(AI)技术打造一个自适应的网络安全防御系统,该系统能够实时分析网络流量,自动识别并响应未知威胁,从而提供更为强大和灵活的保护机制。通过深入剖析AI算法的核心原理及其在网络安全中的应用,我们将展望一个由AI赋能的、更加智能和安全的网络环境。
28 0
|
26天前
|
存储 运维 安全
云擎技术:通信网络单元定级备案指南
简介: 通信网络单元定级备案是指相关基础电信企业、增值电信企业要对本单位管理、运行的公用通信网和互联网及其各类信息系统进行单元划分,按照《通信网络安全防护管理办法》(工业和信息化部令第11号)的规定开展定级工作,并在工业和信息化部“通信网络安全防护管理系统”报送各单元的定级信息。
29 2
|
27天前
|
存储 Unix Linux
深入理解 Linux 系统下的关键网络接口和函数,gethostent,getaddrinfo,getnameinfo
深入理解 Linux 系统下的关键网络接口和函数,gethostent,getaddrinfo,getnameinfo
14 0
|
29天前
|
安全 网络安全 网络虚拟化
【软件设计师备考 专题 】常用网络设备和各类通信设备(三)
【软件设计师备考 专题 】常用网络设备和各类通信设备
33 0