Version 4.5.6 of mod_wsgi can be obtained from:
- Reinstanted change to associate any messages logged via
sys.stderrback to the request so that Apache can log them with the correct request log ID. This change was added in 4.5.4, but was reverted in 4.5.5 as the change was causing process crashes under Python 3.
- When using Apache 2.4 use new style
Requiredirective instead of older
Allowwhen setting up access controls for
mod_wsgi-express. This fixes a problem where when using
Requiredirective was being used. Precedence order was such that older directives were overriding new directive and it was possible to permit access to additional directories when using custom configuration.
- Django 1.10 requires that management commands use argparse style
mod_wsgi-expressuses optparse style options. Can no longer simply merge main script option list to get management command option list. Instead need to convert optparse list to argparse format on the fly, as still need to retain main script option list as optparse until drop Python 2.6 support. Changes stop
runmodwsgimanagement command failing when using Django 1.10+.
WSGIDaemonProcessdirective. If set and the first loading of the WSGI application script file fails, then if no subsequent attempt to load it succeeds within the specified startup timeout, the daemon process will be restarted. When configuring mod_wsgi directly, the option is not enabled by default. The option is exposed via
mod_wsgi-expresswith a default value of 15 seconds.
This would be used where running the Django web framework and there is a risk of the database not being available, causing Django initialisation to fail. Django doesn’t allow initialisation to be performed a second time in the same process, meaning it will then constantly fail. Use of startup timeout will allow the process to be restarted in face of such constant startup failures. If the database is available when the process is restarted, then next time the process starts, everything should be fine.
Do note that this option should preferably only be used where the one WSGI application has been delegated to a WSGI daemon process. This is because if multiple WSGI applications are hosted out of the daemon process group, be they in the same application group or distinct ones, as soon as any one of them loads successfully, then the startup timeout is disabled, meaning that if a subsequent one loaded is constantly failing, then a process restart will not occur. Best practice is to delegate each WSGI application to a distinct daemon process group.