我想通过队列使一个分析器多线程。它似乎工作,但我的队列挂起。如果有人能告诉我如何解决这个问题,我会很感激,因为我很少写多线程代码。Python中的线程队列挂起
此代码从Q写着:
from silk import *
import json
import datetime
import pandas
import Queue
from threading import Thread
l = []
q = Queue.Queue()
def parse_record():
d = {}
while not q.empty():
rec = q.get()
d['timestamp'] = rec.stime.strftime("%Y-%m-%d %H:%M:%S")
# ... many ops like this
d['dport'] = rec.dport
l.append(d) # l is global
这充满问:
def parse_records():
ffile = '/tmp/query.rwf'
flows = SilkFile(ffile, READ)
numthreads = 2
# fill queue
for rec in flows:
q.put(rec)
# work on Queue
for i in range(numthreads):
t = Thread(target = parse_record)
t.daemon = True
t.start()
# blocking
q.join()
# never reached
data_df = pandas.DataFrame.from_records(l)
return data_df
我只在我的主打电话parse_records()
。它永远不会终止。
作为一个方面说明,线程化可能会使其运行速度变慢。 python GIL只允许一次运行一个线程。 CPU绑定的工作人员不会并行运行。 – tdelaney