在 Mac 上运行两个 Jetty 实例时,我遇到了这种特殊的情况:
~$ lsof -ni :9905
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
java 40320 ******* 394u IPv6 0xf5e143eb9100c205 0t0 TCP *:9905 (LISTEN)
java 40325 ******* 302u IPv6 0xf5e143eb79be9005 0t0 TCP 127.0.0.1:9905 (LISTEN)
我尝试在 Python 中重现这种情况,但是失败了(我感觉应该如此):
>>> s = socket.socket()
>>> s.bind(("",12345))
>>> s.listen(1)
>>> z = socket.socket()
>>> z.bind(("localhost",12345))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/socket.py", line 224, in meth
return getattr(self._sock,name)(*args)
socket.error: [Errno 48] Address already in use
我也尝试使用 AF_INET6,结果相同。
有人知道这里发生了什么吗?这怎么可能发生?我以为星号与所有地址绑定在一起……如果这确实是一种正常行为,那么在 python 中重新创建它的正确原因是什么?
谢谢!
答案1
这是在 osx 上重现它的方法。不知道为什么它会起作用(不要告诉任何人,我试图假装自己是 Linux 人),在 Linux 上它不起作用。
>>> import socket
>>> s=socket.socket()
>>> s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
>>> s.bind(("",12345))
>>> s.listen(1)
>>> z=socket.socket()
>>> z.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
>>> z.bind(("127.0.0.1",12345))
>>> z.listen(1)
还有 lsof
Python 7501 danb 3u IPv4 0xac5d4de7add842f 0t0 TCP *:12345 (LISTEN)
Python 7501 danb 4u IPv4 0xac5d4de7bb7928f 0t0 TCP 127.0.0.1:12345 (LISTEN)