From 8e394e87190ce18a8f0147ae4bb8360558f10d52 Mon Sep 17 00:00:00 2001 From: datawhores Date: Fri, 30 Aug 2024 09:39:23 -0500 Subject: [PATCH] only allow multiprocess on Linux --- ofscraper/__main__.py | 1 - .../actions/download/batch/downloadbatch.py | 5 ++-- .../actions/actions/download/download.py | 1 + .../actions/metadata/batch/metadatabatch.py | 2 +- .../actions/actions/metadata/metadata.py | 2 ++ ofscraper/utils/system/system.py | 23 +++++++------------ 6 files changed, 14 insertions(+), 20 deletions(-) diff --git a/ofscraper/__main__.py b/ofscraper/__main__.py index 4ea52c17a..090c90139 100755 --- a/ofscraper/__main__.py +++ b/ofscraper/__main__.py @@ -6,7 +6,6 @@ def main(): - system.set_mulitproc_start_type() if system.get_parent(): load.main() diff --git a/ofscraper/actions/actions/download/batch/downloadbatch.py b/ofscraper/actions/actions/download/batch/downloadbatch.py index 4013de6ab..8ed8f5c56 100644 --- a/ofscraper/actions/actions/download/batch/downloadbatch.py +++ b/ofscraper/actions/actions/download/batch/downloadbatch.py @@ -90,10 +90,9 @@ async def process_dicts(username, model_id, filtered_medialist, posts): count=1, ) log_threads.append(thread) - processes = [ - aioprocessing.AioProcess( - target=process_dict_starter, + aioprocessing.mp.get_context(system.get_mulitproc_start_type()).Process( + target=process_dict_starter, args=( username, model_id, diff --git a/ofscraper/actions/actions/download/download.py b/ofscraper/actions/actions/download/download.py index 8c8f648cd..71925efd6 100644 --- a/ofscraper/actions/actions/download/download.py +++ b/ofscraper/actions/actions/download/download.py @@ -58,6 +58,7 @@ async def download_picker(username, model_id, medialist, posts): >= settings.get_threads() * constants.getattr("DOWNLOAD_THREAD_MIN") ) and settings.not_solo_thread() + and system.platform.system()=="Linux" ): return await batch.process_dicts(username, model_id, medialist, posts) else: diff --git a/ofscraper/actions/actions/metadata/batch/metadatabatch.py b/ofscraper/actions/actions/metadata/batch/metadatabatch.py index 20597c0fa..f0a76b4e7 100644 --- a/ofscraper/actions/actions/metadata/batch/metadatabatch.py +++ b/ofscraper/actions/actions/metadata/batch/metadatabatch.py @@ -74,7 +74,7 @@ def process_dicts(username, model_id, filtered_medialist): log_threads.append(thread) processes = [ - aioprocessing.AioProcess( + aioprocessing.mp.get_context(system.get_mulitproc_start_type()).Process( target=process_dict_starter, args=( username, diff --git a/ofscraper/actions/actions/metadata/metadata.py b/ofscraper/actions/actions/metadata/metadata.py index dc50f0248..5ba91d7b6 100644 --- a/ofscraper/actions/actions/metadata/metadata.py +++ b/ofscraper/actions/actions/metadata/metadata.py @@ -29,6 +29,8 @@ async def metadata_picker(username, model_id, medialist): >= settings.get_threads() * constants.getattr("DOWNLOAD_THREAD_MIN") ) and settings.not_solo_thread() + and system.platform.system()=="Linux" + ): return batch.process_dicts(username, model_id, medialist) else: diff --git a/ofscraper/utils/system/system.py b/ofscraper/utils/system/system.py index 9616baab1..1e6bd655d 100644 --- a/ofscraper/utils/system/system.py +++ b/ofscraper/utils/system/system.py @@ -10,6 +10,8 @@ import multiprocess import psutil from setproctitle import setproctitle +import aioprocessing + def is_frozen(): @@ -47,29 +49,20 @@ def getOpenFiles(unique=True): return out -def set_mulitproc_start_type(): +def get_mulitproc_start_type(): plat = platform.system() if is_frozen(): f_method = "spawn" - multiprocess.set_start_method(f_method) - multiprocessing.set_start_method(f_method) + return f_method elif plat == "Darwin": d_method = "spawn" - multiprocess.set_start_method(d_method) - multiprocessing.set_start_method(d_method) + return d_method elif plat == "Windows": w_method = "spawn" - multiprocess.set_start_method(w_method) - multiprocessing.set_start_method(w_method) + return w_method else: - o_method = "forkserver" - multiprocess.set_start_method(o_method) - multiprocessing.set_start_method(o_method) - # additional for mac - if plat == "Darwin": - os.environ["OBJC_DISABLE_INITIALIZE_FORK_SAFETY"] = "YES" - os.environ["no_proxy"] = "*" - + o_method = "spawn" + return o_method def set_eventloop(): plat = platform.system()