Ответ 1
Вы можете использовать поток для каждого клиента, чтобы избежать блокировки client.recv()
, а затем использовать основной поток только для прослушивания новых клиентов. Когда один подключается, основной поток создает новый поток, который просто слушает нового клиента и заканчивается, когда он не разговаривает в течение 60 секунд.
import socket
import threading
class ThreadedServer(object):
def __init__(self, host, port):
self.host = host
self.port = port
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
self.sock.bind((self.host, self.port))
def listen(self):
self.sock.listen(5)
while True:
client, address = self.sock.accept()
client.settimeout(60)
threading.Thread(target = self.listenToClient,args = (client,address)).start()
def listenToClient(self, client, address):
size = 1024
while True:
try:
data = client.recv(size)
if data:
# Set the response to echo back the recieved data
response = data
client.send(response)
else:
raise error('Client disconnected')
except:
client.close()
return False
if __name__ == "__main__":
while True:
port_num = input("Port? ")
try:
port_num = int(port_num)
break
except ValueError:
pass
ThreadedServer('',port_num).listen()
Время ожидания клиентов после 60 секунд бездействия и должно повторно подключаться. См. Строку client.settimeout(60)
в функции ThreadedServer.listen()