在我的计算机上,安装有 Ubuntu 14.04,我可以执行以下操作:
$ nc -l 5349 -vvv
Listening on [0.0.0.0] (family 0, port 5349)
或这个:
$ nc -vvv -l 192.168.254.96 5349
Listening on [192.168.254.96] (family 0, port 5349)
然后打开一个套接字来监听我本地 IP 地址 (192.168.254.96) 上的连接。显然我可以从另一端连接并传输数据。
但是在 Debian 8.0 Jessie 的 NAT 后面的服务器中我收到了这个奇怪的错误:
$ nc -vvv -l 5349
5349: inverse host lookup failed: Unknown host
nnetfd reuseport failed : Protocol not available
listening on [any] 38541 ... : Protocol not available
或者:
$ nc -vvv -l 10.1.6.189 5349
10.1.6.189: inverse host lookup failed: Unknown host
nnetfd reuseport failed : Protocol not available
listening on [any] 52606 ... : Protocol not available
该端口未被使用:
$ ss -tnl | grep 5349
(empty)
并且这是正确的 IP 地址:
$ ip addr list
...
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 1e:89:93:f1:96:a4 brd ff:ff:ff:ff:ff:ff
inet 10.1.6.189/19 brd 10.1.31.255 scope global eth0
inet6 fe80::1c89:93ff:fef1:96a4/64 scope link
valid_lft forever preferred_lft forever
这可能是什么问题?可能与服务器后面的 NAT 有关吗?
答案1
对于监听模式的 netcat,您应该使用-p
标志来选择监听端口,例如nc -vvv -l -p 5349
。
第二个错误:nnetfd reuseport failed : Protocol not available
与 SO_REUSEPORT 套接字选项有关。它是在 Linux 内核版本 3.9 中引入的,使用它的 netcat 版本将无法与早期内核版本一起使用。您可以将内核升级到较新的版本,也可以使用 netcat 的另一个变体。我相信 netcat-openbsd 应该可以工作。