我正在做一个小插座编程并遇到一些我不理解的网络行为;我希望有人可以了解正在发生的事情。
我在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以外的其他类型的网络连接?
答案 0 :(得分:1)
NAT是您能够从VMWare计算机发送和接收而不是反向的原因。
原因是在发送时,NAT将构建包含原始IP地址和端口的转换表,然后使用不同的IP地址和端口。当答案出现时,将查询此表并将答复委托回原始IP地址和端口。
如果出现了转换表中没有条目的消息,则该消息将被删除。这就是为什么如果你的邻居在那些也使用NATPAT的典型家用路由器后面就不能发送消息说你的邻居的原因。
您可以使用非差别化区域或端口转发来解决此问题。但是如何在vm中做到这一点我不了解。