У меня есть код python с потоками, и мне нужно, если в, например, 1 час потоки не закончены, закончить все потоки и завершить скрипт, а если час не будет завершен, подождите что все мои нити заканчиваются.убить потоки позже время в python
Я пытаюсь с потоком демона и с часом, а если час завершен, используйте: sys.exit()
, но он не работает для меня, потому что всегда жду моего сна threadh, тогда мой скрипт ждет, пока нить завершена и sys.exit()
не работает.
import socket, threading, time, sys
from sys import argv
import os
acc_time=0
transactions_ps=5
ins = open(sys.argv[1],'r')
msisdn_list = []
for line in ins:
msisdn_list.append (line.strip('\n'))
# print line
ins.close()
def worker(msisdn_list):
semaphore.acquire()
global transactions_ps
print " ***** ", threading.currentThread().getName(), "Lanzado"
count=1
acc_time=0
print "len: ",len(msisdn_list)
for i in msisdn_list:
try:
init=time.time()
time.sleep(2)
print "sleeping...",i
time.sleep(4)
final=time.time()
acc_time = acc_time+final-init
print acc_time
except IOError:
print "Connection failed",sys.exc_info()[0]
print "Deteniendo ",threading.currentThread().getName()
semaphore.release()
def kill_process(secs_to_die):
time.sleep(secs_to_die)
sys.exit()
seconds_to_die=3600
thread_kill = threading.Thread(target = kill_process, args=(seconds_to_die,))
thread_kill.start()
max_con=5
semaphore = threading.BoundedSemaphore(max_con)
for i in range(0,28,transactions_ps):
w = threading.Thread(target=worker, args=(msisdn_list[i:i+transactions_ps-1],))
w.setDaemon(True)
w.start()
Как сделать это
Этот код прекрасно работает для меня - он ждет, пока 'secs_do_die' не прошло, то весь сценарий завершается. Это фактический код, который вы используете? – dano
'with open (sys.argv [1]) в качестве файла: msisdn_list = file.read(). Splitlines()' – jfs