У меня есть основной поток, который ждет подключения. Он порождает потоки клиентов, которые будут отражать ответ от клиента (telnet в этом случае). Но скажите, что я хочу закрыть все сокеты и все потоки через некоторое время, например, после 1 соединения. Как мне это сделать? Если я делаю clientSocket.close() из основного потока, это не остановит выполнение recv. Это остановится только в том случае, если я сначала отправлю что-то через telnet, а затем не выполнит дальнейшие отправки и повторы.Как прервать сокет.recv() из другого потока в Python
Мой код выглядит следующим образом:
# Echo server program
import socket
from threading import Thread
import time
class ClientThread(Thread):
def __init__(self, clientSocket):
Thread.__init__(self)
self.clientSocket = clientSocket
def run(self):
while 1:
try:
# It will hang here, even if I do close on the socket
data = self.clientSocket.recv(1024)
print "Got data: ", data
self.clientSocket.send(data)
except:
break
self.clientSocket.close()
HOST = ''
PORT = 6000
serverSocket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
serverSocket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
serverSocket.bind((HOST, PORT))
serverSocket.listen(1)
clientSocket, addr = serverSocket.accept()
print 'Got a new connection from: ', addr
clientThread = ClientThread(clientSocket)
clientThread.start()
time.sleep(1)
# This won't make the recv in the clientThread to stop immediately,
# nor will it generate an exception
clientSocket.close()
Вы не можете делать это с помощью потоков, так как CPython имеет глобальный блокиратор Interpreter. http://docs.python.org/c-api/init.html#threads – badp