Install uWSGI in emperor mode and configure vassals. Requires Ansible 2.4 or later.
NOTE: Some variable names have changed since 0.2.x versions!
The following variables are typically defined to customize this role:
uwsgi_install
: Method to use to install uWSGI; can be"pkg"
(default) to use system package manager or"pip"
to install via pip. Any other value assumes uWSGI is installed by other means.uwsgi_version
: Whenuwsgi_install == "pip"
, specify a version of uWSGI to install. Default is to install the latest version available.uwsgi_virtualenv
: Whenuwsgi_install == "pip"
, installs uWSGI into the specified virtualenv path.uwsgi_vassals
: Create INI configuration files for any vassals specified. Must be a list of hashes, with each hash having at least aname
key to specify file name. All keys and values are written to the INI file under the[uwsgi]
section. Default is[]
.uwsgi_vassals_to_remove
: List of vassal names to remove; default is[]
.
The following variables may be used to customize the configuration and paths used for the uWSGI emperor:
uwsgi_emperor_tyrant
: Run emperor in tyrant mode. Each vassal configuration file will be owned by the uid/gid specified in the vassal options and run as that user instead of the emperor user. Default istrue
whenuwsgi_install == "pip"
,false otherwise
.uwsgi_conf_template
: Local template to use for generating the uWSGI emperor configuration. Default is set fromuwsgi_default_conf_templates[ansible_pkg_mgr]
, which evaluates to"uwsgi.ini.j2"
on EL distributions and"emperor.ini.j2"
on Ubuntu distributions.uwsgi_conf_path
: Path to uWSGI emperor configuration file. Default is set fromuwsgi_default_conf_paths[ansible_pkg_mgr]
, which evaluates to"/etc/uwsgi.ini"
on EL distributions and"/etc/uwsgi-emperor/emperor.ini"
on Ubuntu distributions.uwsgi_conf_force
: Whether to force overwriting the uWSGI emperor configuration file. Default isfalse
to only create the file if it doesn't already exist.uwsgi_vassal_path
: Path for uWSGI emperor to look for vassal configuration files. Default is set fromuwsgi_default_vassal_paths[ansible_pkg_mgr]
, which evaluates to"/etc/uwsgi.d"
on EL distributions and"/etc/uwsgi-emperor/vassals"
on Ubuntu distributions.
The following variables may be used to customize the packages installed to support uWSGI:
uwsgi_os_packages
: List of system packages to install to support uWSGI. Default is set fromuwsgi_default_os_packages[uwsgi_install][ansible_pkg_mgr]
, which will install system packages whenuwsgi_install == "pkg"
and Python development dependences whenuwsgi_install == "pip"
.uwsgi_pip_packages
: List of pip packages to install to support uWSGI whenuwsgi_install == "pip"
. Default is set fromuwsgi_default_pip_packages
, which evaluates to["uwsgi"]
.uwsgi_pip_executable
: Alternate name or path of pip used to install packages whenuwsgi_install == "pip"
and not installing into a virtualenv. Default is to let thepip
module determine which pip executable to use.
The following variables may be used to customize the service configuration when uWSGI is not installed via the system package manager and managed via upstart or systemd:
uwsgi_user_group
: User/group information for running the uWSGI emperor. Default is set fromuwsgi_default_user_group[ansible_pkg_mgr]
, which creates"uwsgi:uwsgi"
system user and group on EL distributions and"www-data:www-data"
system user and group on Ubuntu distributions, the same as would be used by the system package version of uWSGI. The user/group hash may containname
,comment
,group
,home
,shell
andsystem
keys, corresponding to the equivalent parameters to the Ansibleuser
module.uwsgi_service_name
: Name of uWSGI service. Default is set fromuwsgi_default_service_names[ansible_pkg_mgr]
, which evaluates to"uwsgi"
for EL distributions and"uwsgi-emperor"
for Ubuntu distributions.uwsgi_bin
: Path to uWSGI binary to use for upstart or systemd configuration; will be determined automatically if not specified.uwsgi_opts
: Command line options to be used when running uWSGI via upstart or systemd; defaults to running using the options specified in the uWSGI config file:"--die-on-term --ini {{uwsgi_conf_path|quote}}"
.uwsgi_use_upstart
: Boolean indicating whether to use upstart to create and manage the uWSGI service. It is undefined by default, and will only be enabled when uWSGI is not installed via the system package manager on distributions other than EL 7. It can be set tofalse
to explicitly disable using upstart to manage the uWSGI service.uwsgi_upstart_packages
: List of system packages to install to support running uWSGI via upstart. Default is set fromuwsgi_default_upstart_packages[ansible_pkg_mgr]
, which simply installs theupstart
package.uwsgi_upstart_description
: Description for uWSGI upstart service, default is"uWSGI Server"
.uwsgi_upstart_template
: Local template to use for generating the upstart uWSGI configuration; default is"uwsgi-upstart.conf.j2"
.uwsgi_upstart_path
: Path to install upstart uWSGI configuration; default is"/etc/init/{{_uwsgi_service_name}}.conf"
.uwsgi_use_systemd
: Boolean indicating whether to use systemd to create and manage the uWSGI service. It is undefined by default, and will only be enabled when uWSGI is not installed via the system package manager on EL 7 distributions. It can be set tofalse
to explicitly disable using systemd to manage the uWSGI service.uwsgi_systemd_template
: Local template to use for generating the systemd uWSGI service; default is"uwsgi.service.j2"
.uwsgi_systemd_path
: Path to install system uWSGI server; default is"/etc/systemd/system/{{_uwsgi_service_name}}.service"
.
The following example playbook installs uWSGI via pip and configures a single vassal running a Django site:
- hosts: all
roles:
- role: cchurch.uwsgi
vars:
uwsgi_install: pip
uwsgi_vassals:
- name: example
plugin: python
chdir: /opt/example/src
module: example.wsgi
home: /opt/example/env
env: DJANGO_SETTINGS_MODULE=example.settings
processes: 4
socket: 127.0.0.1:8000
uid: example
gid: example
BSD
Chris Church (cchurch)