我想通過隊列使一個分析器多線程。它似乎工作,但我的隊列掛起。如果有人能告訴我如何解決這個問題,我會很感激,因爲我很少寫多線程代碼。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