From beade2b5ffec9c3dcd2f300d20c6fa75e1b9ee38 Mon Sep 17 00:00:00 2001 From: Chris Caron Date: Sat, 22 Jul 2023 16:13:24 -0400 Subject: [PATCH] Updated Gunicorn configuration for resource improvements (#125) --- README.md | 7 ++++--- apprise_api/gunicorn.conf.py | 14 +++++++++++--- requirements.txt | 1 + 3 files changed, 16 insertions(+), 6 deletions(-) diff --git a/README.md b/README.md index b37adc1..fc23324 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ Take advantage of [Apprise](https://github.com/caronc/apprise) through your network with a user-friendly API. -- Send notifications to more than 80+ services. +- Send notifications to more than 90+ services. - An incredibly lightweight gateway to Apprise. - A production ready micro-service at your disposal. @@ -95,7 +95,7 @@ chmod 777 /var/lib/apprise/config ## Dockerfile Details -The following architectures are supported: `386`, `amd64`, `arm/v6`, `arm/v7`, and `arm64`. The following tags can be used: +The following architectures are supported: `amd64`, `arm/v7`, and `arm64`. The following tags can be used: - `latest`: Points to the latest stable build. - `edge`: Points to the last push to the master branch. @@ -285,7 +285,8 @@ The use of environment variables allow you to provide over-rides to default sett | `ALLOWED_HOSTS` | A list of strings representing the host/domain names that this API can serve. This is a security measure to prevent HTTP Host header attacks, which are possible even under many seemingly-safe web server configurations. By default this is set to `*` allowing any host. Use space to delimit more than one host. | `APPRISE_PLUGIN_PATHS` | Apprise supports the ability to define your own `schema://` definitions and load them. To read more about how you can create your own customizations, check out [this link here](https://github.com/caronc/apprise/wiki/decorator_notify). You may define one or more paths (separated by comma `,`) here. By default the `apprise_api/var/plugin` directory is scanned (which does not include anything). Feel free to set this to an empty string to disable any custom plugin loading. | `APPRISE_RECURSION_MAX` | This defines the number of times one Apprise API Server can (recursively) call another. This is to both support and mitigate abuse through [the `apprise://` schema](https://github.com/caronc/apprise/wiki/Notify_apprise_api) for those who choose to use it. When leveraged properly, you can increase this (recursion max) value and successfully load balance the handling of many notification requests through many additional API Servers. By default this value is set to `1` (one). -| `APPRISE_WORKER_COUNT` | Defines the number of workers to run. by default this is calculated based on the number of threads detected. +| `APPRISE_WORKER_COUNT` | Over-ride the number of workers to run. by default this is `(2 * CPUS) + 1` as advised by Gunicorn's website. +| `APPRISE_WORKER_TIMEOUT` | Over-ride the worker timeout value; by default this is `300` (5 min) which should be more than enough time to send all pending notifications. | `BASE_URL` | Those who are hosting the API behind a proxy that requires a subpath to gain access to this API should specify this path here as well. By default this is not set at all. | `LOG_LEVEL` | Adjust the log level to the console. Possible values are `CRITICAL`, `ERROR`, `WARNING`, `INFO`, and `DEBUG`. | `DEBUG` | This defaults to `no` and can however be set to `yes` by simply defining the global variable as such. diff --git a/apprise_api/gunicorn.conf.py b/apprise_api/gunicorn.conf.py index 66eb8ca..81efdc5 100644 --- a/apprise_api/gunicorn.conf.py +++ b/apprise_api/gunicorn.conf.py @@ -1,6 +1,6 @@ # -*- coding: utf-8 -*- # -# Copyright (C) 2019 Chris Caron +# Copyright (C) 2023 Chris Caron # All rights reserved. # # This code is licensed under the MIT License. @@ -46,8 +46,16 @@ workers = int(os.environ.get( 'APPRISE_WORKER_COUNT', multiprocessing.cpu_count() * 2 + 1)) # Increase worker timeout value to give upstream services time to -# respond -timeout = 90 +# respond. +timeout = int(os.environ.get('APPRISE_WORKER_TIMEOUT', 300)) + +# Our worker type to use; over-ride the default `sync` +worker_class = 'gevent' + +# Get workers memory consumption under control by leveraging gunicorn worker recycling +# timeout +max_requests = 1000 +max_requests_jitter = 50 # Logging # '-' means log to stdout. diff --git a/requirements.txt b/requirements.txt index 8e963a2..7bc57bc 100644 --- a/requirements.txt +++ b/requirements.txt @@ -1,5 +1,6 @@ django apprise == 1.4.5 +gevent gunicorn # 3rd party service support