在Ubuntu Server上用Python无法看到Socket
我正在写一个应用程序,它的功能是监听客户端的连接,当客户端连接上来时,它会抓取一些数据。在我自己的电脑或者服务器上运行的时候,一切都很正常,但当我在服务器上运行这个程序,然后从我的电脑连接时,它就完全不工作了,连接超时。
我尝试过先运行这个程序,然后在服务器上检查一下网络状态(netstat),只有当我把主机设置为localhost时,才会显示一些信息。如果我把主机设置为服务器的IP地址(或者主机名,或者socket.getfqdn()
),那么在netstat中就什么都看不见。
以下是代码:
class Listen(threading.Thread):
def __init__(self):
self.PORT = 2079
self.HOST = socket.getfqdn()
threading.Thread.__init__(self)
self.finished = threading.Event()
def stop(self):
self.finished.set()
self.join()
def run(self):
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server.bind((self.HOST, self.PORT))
server.listen(5)
while not self.finished.isSet():
try:
server.settimeout(1)
channel, details = server.accept()
server.settimeout(None)
Client(channel, details).start()
except socket.timeout:
pass
class Client(threading.Thread):
def __init__(self, channel, details):
self.channel = channel
self.details = details
self.log = []
threading.Thread.__init__(self)
def run(self):
print 'Received connection:', self.details [ 0 ]
entries = int(self.channel.recv(3))
print "Receiving", entries, "new entries"
for i in range(entries):
self.log.append([])
self.log[i].append(float(self.channel.recv(10)))
self.log[i].append(float(self.channel.recv(10)))
self.log[i].append(self.channel.recv(14))
self.channel.close()
print 'Closed connection:', self.details [ 0 ]
print "The obtained log: "
print self.log
def main():
listen = Listen()
listen.start()
while True:
input = raw_input(">>").lower()
if input in ["start"]:
if listen.isAlive():
print "Already started"
else:
listen = Listen()
listen.start()
if input in ["stop"]:
if not listen.isAlive():
print "Already stopped"
else:
listen.stop()
if input in ["exit"]:
if listen.isAlive():
listen.stop()
sys.exit()
if input in ["status"]:
print "The server is " + ["not ", ""][listen.isAlive()] + "running"
if __name__ == '__main__':
main()
1 个回答
3
不要用 server.bind((self.HOST, self.PORT))
,试试这个:
server.bind(('', self.PORT))
对于IPv4地址,空字符串代表INADDR_ANY;当你接收到一个绑定到这个地址的套接字时,你的程序会从所有网络接口接收到数据包(不仅仅是回环接口或主要的以太网接口)。