我收到了以下错误信息:
插槽信号量的作用是限制活动线程的数量,但我认为我从未达到过1000个线程。之前我认为这个错误是由于我的线程数组指向线程导致的,所以我添加了代码,在它们不再活动时将它们从数组中删除。
我无法理解为什么只有59个活动线程时就无法启动新线程。
此外,有没有更好的方法来实现我正在尝试做的事情?每个线程都向API发送请求。我尝试过不使用并发,但甚至无法接近我的速率限制。
----- Match 93028: ------ Patch 5.11 ------78 Threads Active
----- Match 93029: ------ Patch 5.11 ------77 Threads Active
----- Match 93030: ------ Patch 5.11 ------76 Threads Active
----- Match 93031: ------ Patch 5.11 ------71 Threads Active
----- Match 93032: ------ Patch 5.11 ------55 Threads Active
----- Match 93033: ------ Patch 5.11 ------56 Threads Active
----- Match 93034: ------ Patch 5.11 ------57 Threads Active
----- Match 93035: ------ Patch 5.11 ------58 Threads Active
----- Match 93036: ------ Patch 5.11 ------59 Threads Active
Traceback (most recent call last):
File "pulldata.py", line 91, in <module>
getPatchData('5.11', '511')
File "pulldata.py", line 64, in getPatchData
matchThread.start()
File "/usr/lib/python3.4/threading.py", line 850, in start
_start_new_thread(self._bootstrap, ())
RuntimeError: can't start new thread
通常这是由于打开了太多的线程所致,但您可以看到我也在打印活动线程数。当前有<100个活动线程,所以我不确定问题出在哪里。下面是相关代码:
slot = threading.BoundedSemaphore(value=1000)
def getMatchData(index,match,patch):
global requestsSent
global logfile
print("----- Match {0}: ------ Patch {1} ------{2} Threads Active".format(index,patch,threading.active_count()))
logfile.write("Parsing Match {0} for patch {1}:\n".format(index,patch))
#match is a class. get is a function that sends a request to the server and returns a request object from where I get the json response.
data = match.get().json()
#processdata
slot.release()
def getPatchData(patch, name):
global logfile
threads = []
matches = getAllMatches(patch)
for index, match in enumerate(matches):
slot.acquire()
matchThread = threading.Thread(target=getMatchData, args=(index,match,patch))
threads.append(matchThread)
matchThread.start()
for t in threads:
if not t.isAlive():
threads.remove(t)
for t in threads:
t.join()
插槽信号量的作用是限制活动线程的数量,但我认为我从未达到过1000个线程。之前我认为这个错误是由于我的线程数组指向线程导致的,所以我添加了代码,在它们不再活动时将它们从数组中删除。
我无法理解为什么只有59个活动线程时就无法启动新线程。
此外,有没有更好的方法来实现我正在尝试做的事情?每个线程都向API发送请求。我尝试过不使用并发,但甚至无法接近我的速率限制。