我有一个线程 python 套接字服务器,它为每个连接打开一个新线程。
线程是基于问答的非常简单的通信。基本上客户端发送初始数据传输,服务器让它运行一个外部应用程序,该应用程序对传输进行处理并返回服务器将发回的回复,并且循环将再次开始,直到客户端断开连接。
现在,因为客户端将在手机上,因此连接不稳定,我得到的开放线程不再连接,并且由于循环以 recv 开始,因此很难以这种方式中断丢失的连接。
我正在考虑在 recv 之前添加一个发送来测试连接是否仍然存在,但是如果客户端在我的故障安全发送之后断开连接,因为客户端仅每 5 秒发送一个数据流,这可能根本无济于事。
我注意到 recv 有时会中断,但并非总是如此,在这些情况下,我会留下使用资源的僵尸线程。
这也可能是我的系统被DOSed的一个可靠漏洞。自从星期四以来,我已经浏览了 python 手册和谷歌搜索,但我发现的大多数东西都与客户端和非阻塞模式有关。
谁能指出我解决此问题的正确方向?
代码示例:
听众:
serversocket = socket(AF_INET, SOCK_STREAM)
serversocket.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
serversocket.bind(addr)
serversocket.listen(2)
logg("Binded to port: " + str(port))
# Listening Loop
while 1:
clientsocket, clientaddr = serversocket.accept()
threading.Thread(target=handler, args=(clientsocket, clientaddr,port,)).start()
# This is useless as it will never get here
serversocket.close()
处理程序:
# Socket connection handler (Threaded)
def handler(clientsocket, clientaddr, port):
clientsocket.settimeout(15)
# Loop till client closes connection or connection drops
while 1:
stream = ''
while 1:
ending = stream[-6:] # get stream ending
if ending == '.$$$$.':
break
try:
data = clientsocket.recv(1)
except:
sys.exit()
if not data:
sys.exit()
# this is the usual point where thread is closed when a client closes connection normally
stream += data
# Clear the line ending
stream = base64.b64encode(stream[:-6])
# Send data to be processed
re = getreply(stream)
# Send response to client
try:
clientsocket.send(re + str('.$$$$.'))
except:
sys.exit()
如您所见,如果连接失败,至少有一种情况应该触发退出,但有时它们不会触发三种情况。