我有一个多线程程序,它实例化5个套接字对象:
class myThread (threading.Thread):
def __init__(self, pid, port_num, restart):
threading.Thread.__init__(self)
self.hostname = '127.0.0.1'
self.pid = pid
self.port_num = port_num
self.ID = pid
self.restart = restart
self.delay = pid*4*1000
def run(self):
try:
s = timer(self.hostname, self.port_num, self.pid)
#print "Socket S run"+str(s)
sendToSocket(self.pid, s, self.t, self.ID)
except Exception as e:
raise
此处函数timer
用于以下列方式实例化线程:
def timer(host, port, pid):
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
timed = pid * 4 * 100
s.settimeout(timed)
s.bind((host, port))
s.listen(5)
return s
我想终止特定端口的一个套接字,比如说5005。 上例中的pid从5001到5005。
我想在两者之间关闭套接字 - 比如5005 。
所以我用这个方法:
s = socket.socket()
s.connect(('127.0.0.1', 5005))
s.close()
但Socket没有关闭。
我需要从外部函数调用上面的过程。
简而言之,如果有一个套接字绑定到端口5005,我想关闭套接字并使其不可用,以便我们得到一个Port not found exception.
答案 0 :(得分:2)
您可以创建一个字典,其中port为key,socket为value。
my_sockets = {}
然后在run
或timer
函数中添加该字典中的所有新套接字。
def timer(host, port, pid):
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
timed = pid * 4 * 100
s.settimeout(timed)
s.bind((host, port))
s.listen(5)
my_sockets[port] = s
return s
最后创建一个函数来关闭并从该字典中删除套接字。
def close_socket(port):
if port in my_sockets :
my_sockets[port].close()
my_sockets.pop(port)