从Windows PC向VMware计算机发送UDP消息时使用的网络连接?

时间:2015-10-11 01:33:52

标签: sockets udp vmware nat

我正在做一个小插座编程并遇到一些我不理解的网络行为;我希望有人可以了解正在发生的事情。

我在PC上运行Windows 7 Professional。我已经安装了VMware,并且正在运行QNX Neutrino RTOS作为VMware会话中的目标。因此Windows PC是主机PC,客户操作系统是QNX Neutrino RTOS。我将虚拟机配置为使用NAT网络连接。

好的,现在进入IP和接口配置。正在运行' ipconfig'在我的Windows机器上提供以下内容:

Windows IP Configuration

Ethernet adapter Local Area Connection:

  Connection-specific DNS Suffix  . :
  IPv4 Address. . . . . . . . . . . : 192.168.1.100
  Subnet Mask . . . . . . . . . . . : 255.255.255.0
  Default Gateway . . . . . . . . . : 192.168.1.1

Ethernet adapter VMware Network Adapter VMnet1:

  Connection-specific DNS Suffix  . :
  Link-local IPv6 Address . . . . . : fe80::c558:ae9f:e58e:e005%24
  IPv4 Address. . . . . . . . . . . : 192.168.184.1
  Subnet Mask . . . . . . . . . . . : 255.255.255.0
  Default Gateway . . . . . . . . . :

Ethernet adapter VMware Network Adapter VMnet8:

  Connection-specific DNS Suffix  . :
  Link-local IPv6 Address . . . . . : fe80::fce2:d22f:9ec:bd005%25
  IPv4 Address. . . . . . . . . . . : 192.168.248.1
  Subnet Mask . . . . . . . . . . . : 255.255.255.0
  Default Gateway . . . . . . . . . :

(** Other entries omitted for brevity **)

当我跑#if; ifconfig'在VMware QNX系统上,我得到以下内容:

lo0: flags=8049<UP,LOOPBACK,RUNNING,MULTICAST> mtu 33192
        inet 127.0.0.1 netmask 0xff000000
ni0: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> mtu 1500
        capabilities rx=7<IP4CSUM,TCP4CSUM,UDP4CSUM>
        capabilities tx=3f<IP4CSUM,TCP4CSUM,UDP4CSUM,TCP6CSUM,UDP6CSUM,TSO4>
        enabled=0
        address: 00:0c:29:04:00:ae
        media: Ethernet autoselect (1000baseT full-duplex)
        status: active
        inet 192.168.184.15 netmask 0xffffff00 broadcast 192.168.184.255
ni1: flags=8843<UP,BROADCAST,RUNNING,SIMPLEX,MULTICAST> mtu 1500
        capabilities rx=7<IP4CSUM,TCP4CSUM,UDP4CSUM>
        capabilities tx=3f<IP4CSUM,TCP4CSUM,UDP4CSUM,TCP6CSUM,UDP6CSUM,TSO4>
        enabled=0
        address: 00:0c:29:04:00:b8
        media: Ethernet autoselect (1000baseT full-duplex)
        status: active
        inet 192.168.248.15 netmask 0xffffff00 broadcast 192.168.248.255

到目前为止,这么好。现在,我在VMware计算机上运行的套接字程序可以成功地从VMware IP地址192.168.184.15(端口65527)向Windows PC 192.168.1.100(端口2023)发送UDP消息,并且我的Windows套接字程序收到该消息。但是,当我尝试从IP地址为192.168.1.100(端口2044)的Windows计算机向192.168.248.15(端口2045)的VMware计算机发送UDP消息时,消息无法以某种方式到达目的地。我确实使用Wireshark验证UDP消息是否具有预期的IP源地址和IP目标地址,但即便如此,在VMware计算机上运行的套接字程序也没有收到UDP消息。

但我能做的是从Windows机器发送UDP消息,IP地址为192.168.248.1到192.168.248.15。执行此操作时,VMware计算机上运行的套接字程序将获取UDP消息。但我想知道的是为什么我无法成功地将消息从192.168.1.100发送到192.168.248.15?我是否需要使用NAT以外的其他类型的网络连接?

1 个答案:

答案 0 :(得分:1)

NAT是您能够从VMWare计算机发送和接收而不是反向的原因。

原因是在发送时,NAT将构建包含原始IP地址和端口的转换表,然后使用不同的IP地址和端口。当答案出现时,将查询此表并将答复委托回原始IP地址和端口。

如果出现了转换表中没有条目的消息,则该消息将被删除。这就是为什么如果你的邻居在那些也使用NATPAT的典型家用路由器后面就不能发送消息说你的邻居的原因。

您可以使用非差别化区域或端口转发来解决此问题。但是如何在vm中做到这一点我不了解。