我正在尝试虚拟化多个IP地址的telnet服务器。同时仍然能够与相同的远程服务器通信。
在虚拟化 IP 上运行的 UNIX TCP 套接字的正确文件路径是什么?还是有没有办法在本地连接并忽略路由表?
我已经在环回上虚拟化了IP,如下所示:
lo0: flags=8049<UP,LOOPBACK,RUNNING,MULTICAST> mtu 16384
options=3<RXCSUM,TXCSUM>
inet6 ::1 prefixlen 128
inet 127.0.0.1 netmask 0xff000000
inet6 fe80::1%lo0 prefixlen 64 scopeid 0x1
inet 10.10.0.24 netmask 0xff000000
inet 192.168.10.2 netmask 0xffffff00
inet 192.168.10.3 netmask 0xffffff00
inet 192.168.10.4 netmask 0xffffff00
nd6 options=1<PERFORMNUD>
路由表配置了静态路由,以便出站连接仍然可以到达预期目标。(我试过关闭它,但它仍然没有帮助)
Routing tables
Internet:
Destination Gateway Flags Refs Use Netif Expire
192.168.10.2 192.168.10.2 UH 0 75 en1
192.168.10.3 192.168.10.3 UH 0 75 en1
192.168.10.4 192.168.10.4 UH 0 75 en1
我可以确认服务器正在侦听并绑定到正确的套接字。
sudo lsof -i -n | grep 'telnet'
Python 69212 root 6u IPv4 0x7002eb6c7a9b50e1 0t0 TCP 192.168.10.4:telnet (LISTEN)
Python 69212 root 7u IPv4 0x7002eb6c7db219b1 0t0 TCP 192.168.10.3:telnet (LISTEN)
Python 69212 root 8u IPv4 0x7002eb6c4f254b51 0t0 TCP 192.168.10.2:telnet (LISTEN)
我尝试了几种不同的连接到本地服务器的方法。并删除了本地服务器,以便我可以证明我正在本地连接。
telnet -u /dev/tcp/192.168.10.5/23
Trying /dev/tcp/192.168.10.5/23...
/dev/tcp/192.168.10.5/23: No such file or directory
socat -v READLINE UNIX-CONNECT:/dev/tcp/192.168.10.5/23
2015/01/27 11:32:39 socat[92588] E connect(6, LEN=26 AF=1 "/dev/tcp/192.168.10.5/23", 26): No such file or directory
你把事情搞混了。
UNIX套接字是一回事:它们使用文件系统中的对象,这些对象具有路径,可以用它们寻址。
TCP/IP套接字是另一回事。您可以对它们执行相同的操作,但处理方式不同。
使用远程登录,您将可以
telnet -u 192.168.10.5
有了索卡特,就像
socat -v READLINE TCP:192.168.10.5:23
/dev/tcp
的东西只是由外壳构成的东西;它并不真正存在。