Merge pull request #410 from mammo0/fix_for_#350

Use a semaphore to avoid fetching complete library to memory
This commit is contained in:
mcarlton00 2020-11-02 10:09:11 -05:00 committed by GitHub
commit 7d792ab50b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -7,7 +7,7 @@ import threading
import concurrent.futures import concurrent.futures
from datetime import date from datetime import date
from six.moves import range, queue as Queue, zip from six.moves import range, queue as Queue
from kodi_six import xbmc from kodi_six import xbmc
import requests import requests
@ -280,14 +280,33 @@ def _get_items(query, server_id=None):
# complete all tasks before allowing any results to be processed. ThreadPoolExecutor # complete all tasks before allowing any results to be processed. ThreadPoolExecutor
# allows for completed tasks to be processed while other tasks are completed on other # allows for completed tasks to be processed while other tasks are completed on other
# threads. Dont be a dummy.Pool, be a ThreadPoolExecutor # threads. Dont be a dummy.Pool, be a ThreadPoolExecutor
p = concurrent.futures.ThreadPoolExecutor(dthreads) with concurrent.futures.ThreadPoolExecutor(dthreads) as p:
# dictionary for storing the jobs and their results
jobs = {}
results = p.map(lambda params: _get(url, params, server_id=server_id), query_params) # semaphore to avoid fetching complete library to memory
thread_buffer = threading.Semaphore(dthreads)
for params, result in zip(query_params, results): # wrapper function for _get that uses a semaphore
query['params'] = params def get_wrapper(params):
thread_buffer.acquire()
return _get(url, params, server_id=server_id)
result = result or {'Items': []} # create jobs
for param in query_params:
job = p.submit(get_wrapper, param)
# the query params are later needed again
jobs[job] = param
# process complete jobs
for job in concurrent.futures.as_completed(jobs):
# get the result
result = job.result() or {'Items': []}
query['params'] = jobs[job]
# free job memory
del jobs[job]
del job
# Mitigates #216 till the server validates the date provided is valid # Mitigates #216 till the server validates the date provided is valid
if result['Items'][0].get('ProductionYear'): if result['Items'][0].get('ProductionYear'):
@ -304,6 +323,9 @@ def _get_items(query, server_id=None):
yield items yield items
del items['Items'][:] del items['Items'][:]
# release the semaphore again
thread_buffer.release()
class GetItemWorker(threading.Thread): class GetItemWorker(threading.Thread):