From 858eed61742f9e65222775cc812208505616a985 Mon Sep 17 00:00:00 2001 From: Your Name Date: Wed, 20 Mar 2024 12:52:15 +0800 Subject: [PATCH] Manually release memory footprint to avoid OOM that may occur after long-term use --- fooocusapi/worker.py | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/fooocusapi/worker.py b/fooocusapi/worker.py index 6fef5e1..f6e3e68 100644 --- a/fooocusapi/worker.py +++ b/fooocusapi/worker.py @@ -12,6 +12,7 @@ from fooocusapi.task_queue import QueueTask, TaskQueue, TaskOutputs worker_queue: TaskQueue = None +last_model_name = None def process_top(): import ldm_patched.modules.model_management @@ -118,6 +119,17 @@ def yield_result(_, imgs, tasks, extension='png'): try: print(f"[Task Queue] Task queue start task, job_id={async_task.job_id}") + # clear memory + global last_model_name + + if last_model_name is None: + last_model_name = async_task.req_param.base_model_name + if last_model_name != async_task.req_param.base_model_name: + model_management.cleanup_models() # key1 + model_management.unload_all_models() + model_management.soft_empty_cache() # key2 + last_model_name = async_task.req_param.base_model_name + worker_queue.start_task(async_task.job_id) execution_start_time = time.perf_counter()