你好,游客 登录 注册 搜索
背景:
阅读新闻

从外网访问VMware虚拟机的Web服务

[日期:2017-01-13] 来源:Linux社区  作者:Linux [字体: ]

   在主机上安装了VMware,VMware上安装了Linux或Windows虚拟机。我想让虚拟机向外提供Web服务,于是在它上面打开了IIS(Windows)。本文讲解如何让我的主机和外网用户可以访问IIS的网站。

    我的情景是这样的:主机(Windows 7)位于局域网内,要在主机上VMware安装Windows 7虚拟机;虚拟机上安装Team Foundation Server2010,并向局域网其他用户提供TFS网站的访问。这里分解成几个步骤。

  • 网络拓扑
  • 原理说明
  • VMware的NAT设置
  • 端口转发(Port Forwarding)
  • 路由器和防火墙设置
  • 网络测试

网络拓扑

   该前提下的网络拓扑有3种主要类型:家庭ADSL、公司局域网和托管机房公网。我的情景是第二种。

从外网访问VMware虚拟机的Web服务

原理说明

    有了拓扑之后,需要了解VMware的三种网络连接模式, 区分桥接(bridged)、NAT和Host-only。桥接模式,可以看成主机与虚拟机用Hub相连接。NAT是局域网的重要技术,详细解释可以看百 科。NAT模式,可看成主机是关口,虚拟机在网络内部,所有与虚拟机的通信均要经过关口。Host-only模式,看成主机与虚拟机是用双绞线相连的,它 们可分别处于独立的网段。

    公司局域网采用域管理,即虚拟机没有(申请)在域内,而主机在域内。所以我只能采用NAT模式,否则虚拟机没有访问网络(或被访问)的权限。

VMware的NAT设置

  • 右键点击虚拟机,选择“setting”;
  • 在左边栏的Hardware选项卡内选择Network Adapter;
  • 在右边栏选择NAT,如下图:

  

端口转发(Port Forwarding)

    在完成NAT设置之后,虚拟机便可以访问外部网络(局域网其他用户和Internet)了。但是,从外部网络不能访问虚拟机。这是因为NAT对外是屏蔽内部网络细节的。为了实现从外部访问虚拟机,则需要设置端口转发。

  • 查看虚拟机的IP地址

  • 在VMware的菜单项Edit下选择Vitual Network Editor;在上方选定NAT网络,在下方选择NAT(shared host's IP address with VMs),点击NAT Settings;

  • 点击Add添加端口转发;

    Host Port是主机的端口,即从外网访问主机该端口的请求,均转发至虚拟机;

    Type指定传输协议,这里添加了TCP和UDP(Http一般只使用TCP);

    Vitual Machine IP Address填写虚拟机的IP地址和端口;由于这里需提供Web服务,所以应该填写Web端口(在windows IIS的网站中设定);

路由器和防火墙设置

  • 在外部网络与主机间若有路由器,则需设置端口映射;我的情景下没有;
  • 关闭主机上的防火墙,或者设置防火墙的端口允许规则;

网络测试

  • TFS的IIS网站已经搭建好;
  • 在局域网其他用户的计算机上打开浏览器,访问http://<host's IP address>:host port;

     假设主机的IP为10.1.1.1,则在浏览器访问http://10.1.1.1:8080。正常情况下,访问请求会转发至虚拟机,即该请求实际访问的是http://192.168.75.134:8080。

  • 若正常打开Web网站,则测试通过。

本文永久更新链接地址http://www.linuxidc.com/Linux/2017-01/139529.htm

linux
本文评论   查看全部评论 (0)
表情: 表情 姓名: 字数

       

评论声明
  • 尊重网上道德,遵守中华人民共和国的各项有关法律法规
  • 承担一切因您的行为而直接或间接导致的民事或刑事法律责任
  • 本站管理人员有权保留或删除其管辖留言中的任意内容
  • 本站有权在网站内转载或引用您的评论
  • 参与本评论即表明您已经阅读并接受上述条款