تنظیم max_request در Gunicorn در برنامههای Python
در Gunicorn، پارامتر max_requests تعداد درخواستهایی را که هر Worker باید قبل از retirement (خاتمه کار) پردازش کند، مشخص میکند. پس از رسیدن یک Worker به این اندازه، به طور خودکار retired میشود و یک Worker جدید جایگزین آن میشود.
یکی از راههای جلوگیری از نشت حافظه و مصرف بالای RAM در Gunicorn، تنظیم پارامتر max_requests است. با تنظیم این پارامتر، با رسیدن تعداد درخواستهای هر یک از Threadهای Gunicorn به این عدد، آن Thread ریاستارت شده و حافظهی RAM آن خالی میشود. در صورتی که در برنامهی Python خود نیاز به ریاستارت WORKER THREAD بعد از تعداد مشخصی Request دارید، میتوانید طبق مستندات تنظیم متغیرهای محیطی، متغیر محیطی GUNICORN_MAX_REQUESTS را با مقدار 1000 به برنامه Python خود، اضافه کنید.
مقدار پیشفرض این متغیر در برنامههای Python، برابر با 10000 است.