Provided by: supervisor_3.3.1-1.1_all 

NAME
supervisord - supervisord Documentation
Supervisor is a client/server system that allows its users to monitor and control a number of processes
on UNIX-like operating systems.
It shares some of the same goals of programs like launchd, daemontools, and runit. Unlike some of these
programs, it is not meant to be run as a substitute for init as "process id 1". Instead it is meant to be
used to control processes related to a project or a customer, and is meant to start like any other
program at boot time.
DOCUMENTATION
supervisord
The server piece of supervisor is named supervisord. It is responsible for starting child programs at
its own invocation, responding to commands from clients, restarting crashed or exited subprocesseses,
logging its subprocess stdout and stderr output, and generating and handling "events" corresponding to
points in subprocess lifetimes.
The server process uses a configuration file. This is typically located in /etc/supervisord.conf. This
configuration file is a "Windows-INI" style config file. It is important to keep this file secure via
proper filesystem permissions because it may contain unencrypted usernames and passwords.
Running Supervisor
This section makes reference to a BINDIR when explaining how to run the supervisord and supervisorctl
commands. This is the "bindir" directory that your Python installation has been configured with. For
example, for an installation of Python installed via ./configure --prefix=/usr/local/py; make; make
install, BINDIR would be /usr/local/py/bin. Python interpreters on different platforms use a different
BINDIR. Look at the output of setup.py install if you can't figure out where yours is.
Adding a Program
Before supervisord will do anything useful for you, you'll need to add at least one program section to
its configuration. The program section will define a program that is run and managed when you invoke the
supervisord command. To add a program, you'll need to edit the supervisord.conf file.
One of the simplest possible programs to run is the UNIX cat program. A program section that will run
cat when the supervisord process starts up is shown below.
[program:foo]
command=/bin/cat
This stanza may be cut and pasted into the supervisord.conf file. This is the simplest possible program
configuration, because it only names a command. Program configuration sections have many other
configuration options which aren't shown here. See programx_section for more information.
Running supervisord
To start supervisord, run $BINDIR/supervisord. The resulting process will daemonize itself and detach
from the terminal. It keeps an operations log at $CWD/supervisor.log by default.
You may start the supervisord executable in the foreground by passing the -n flag on its command line.
This is useful to debug startup problems.
WARNING:
When supervisord starts up, it will search for its configuration file in default locations including
the current working directory. If you are security-conscious you will probably want to specify a "-c"
argument after the supervisord command specifying an absolute path to a configuration file to ensure
that someone doesn't trick you into running supervisor from within a directory that contains a rogue
supervisord.conf file. A warning is emitted when supervisor is started as root without this -c
argument.
To change the set of programs controlled by supervisord, edit the supervisord.conf file and kill -HUP or
otherwise restart the supervisord process. This file has several example program definitions.
The supervisord command accepts a number of command-line options. Each of these command line options
overrides any equivalent value in the configuration file.
supervisord Command-Line Options
-c FILE, --configuration=FILE
The path to a supervisord configuration file.
-n, --nodaemon
Run supervisord in the foreground.
-h, --help
Show supervisord command help.
-u USER, --user=USER
UNIX username or numeric user id. If supervisord is started as the root user, setuid to this user
as soon as possible during startup.
-m OCTAL, --umask=OCTAL
Octal number (e.g. 022) representing the umask that should be used by supervisord after it starts.
-d PATH, --directory=PATH
When supervisord is run as a daemon, cd to this directory before daemonizing.
-l FILE, --logfile=FILE
Filename path to use as the supervisord activity log.
-y BYTES, --logfile_maxbytes=BYTES
Max size of the supervisord activity log file before a rotation occurs. The value is
suffix-multiplied, e.g "1" is one byte, "1MB" is 1 megabyte, "1GB" is 1 gigabyte.
-y NUM, --logfile_backups=NUM
Number of backup copies of the supervisord activity log to keep around. Each logfile will be of
size logfile_maxbytes.
-e LEVEL, --loglevel=LEVEL
The logging level at which supervisor should write to the activity log. Valid levels are trace,
debug, info, warn, error, and critical.
-j FILE, --pidfile=FILE
The filename to which supervisord should write its pid file.
-i STRING, --identifier=STRING
Arbitrary string identifier exposed by various client UIs for this instance of supervisor.
-q PATH, --childlogdir=PATH
A path to a directory (it must already exist) where supervisor will write its AUTO -mode child
process logs.
-k, --nocleanup
Prevent supervisord from performing cleanup (removal of old AUTO process log files) at startup.
-a NUM, --minfds=NUM
The minimum number of file descriptors that must be available to the supervisord process before it
will start successfully.
-t, --strip_ansi
Strip ANSI escape sequences from all child log process.
-v, --version
Print the supervisord version number out to stdout and exit.
--profile_options=LIST
Comma-separated options list for profiling. Causes supervisord to run under a profiler, and
output results based on the options, which is a comma-separated list of the following: cumulative,
calls, callers. E.g. cumulative,callers.
--minprocs=NUM
The minimum number of OS process slots that must be available to the supervisord process before it
will start successfully.
Signals
The supervisord program may be sent signals which cause it to perform certain actions while it's running.
You can send any of these signals to the single supervisord process id. This process id can be found in
the file represented by the pidfile parameter in the [supervisord] section of the configuration file (by
default it's $CWD/supervisord.pid).
Signal Handlers
SIGTERM
supervisord and all its subprocesses will shut down. This may take several seconds.
SIGINT
supervisord and all its subprocesses will shut down. This may take several seconds.
SIGQUIT
supervisord and all its subprocesses will shut down. This may take several seconds.
SIGHUP
supervisord will stop all processes, reload the configuration from the first config file it finds, and
restart all processes.
SIGUSR2
supervisord will close and reopen the main activity log and all child log files.
Runtime Security
The developers have done their best to assure that use of a supervisord process running as root cannot
lead to unintended privilege escalation. But caveat emptor. Supervisor is not as paranoid as something
like DJ Bernstein's daemontools, inasmuch as supervisord allows for arbitrary path specifications in its
configuration file to which data may be written. Allowing arbitrary path selections can create
vulnerabilities from symlink attacks. Be careful when specifying paths in your configuration. Ensure
that the supervisord configuration file cannot be read from or written to by unprivileged users and that
all files installed by the supervisor package have "sane" file permission protection settings.
Additionally, ensure that your PYTHONPATH is sane and that all Python standard library files have
adequate file permission protections.
Running supervisord automatically on startup
If you are using a distribution-packaged version of Supervisor, it should already be integrated into the
service management infrastructure of your distribution.
There are user-contributed scripts for various operating systems at:
https://github.com/Supervisor/initscripts
There are some answers at Serverfault in case you get stuck: How to automatically start supervisord on
Linux (Ubuntu)
Subprocesses
supervisord's primary purpose is to create and manage processes based on data in its configuration file.
It does this by creating subprocesses. Each subprocess spawned by supervisor is managed for the entirety
of its lifetime by supervisord (supervisord is the parent process of each process it creates). When a
child dies, supervisor is notified of its death via the SIGCHLD signal, and it performs the appropriate
operation.
Nondaemonizing of Subprocesses
Programs meant to be run under supervisor should not daemonize themselves. Instead, they should run in
the foreground. They should not detach from the terminal from which they are started.
The easiest way to tell if a program will run in the foreground is to run the command that invokes the
program from a shell prompt. If it gives you control of the terminal back, but continues running, it's
daemonizing itself and that will almost certainly be the wrong way to run it under supervisor. You want
to run a command that essentially requires you to press Ctrl-C to get control of the terminal back. If
it gives you a shell prompt back after running it without needing to press Ctrl-C, it's not useful under
supervisor. All programs have options to be run in the foreground but there's no "standard way" to do
it; you'll need to read the documentation for each program.
Below are configuration file examples that are known to start common programs in "foreground" mode under
Supervisor.
Examples of Program Configurations
Here are some "real world" program configuration examples:
Apache 2.2.6
[program:apache2]
command=/path/to/httpd -c "ErrorLog /dev/stdout" -DFOREGROUND
redirect_stderr=true
Two Zope 2.X instances and one ZEO server
[program:zeo]
command=/path/to/runzeo
priority=1
[program:zope1]
command=/path/to/instance/home/bin/runzope
priority=2
redirect_stderr=true
[program:zope2]
command=/path/to/another/instance/home/bin/runzope
priority=2
redirect_stderr=true
Postgres 8.X
[program:postgres]
command=/path/to/postmaster
; we use the "fast" shutdown signal SIGINT
stopsignal=INT
redirect_stderr=true
OpenLDAP slapd
[program:slapd]
command=/path/to/slapd -f /path/to/slapd.conf -h ldap://0.0.0.0:8888
redirect_stderr=true
Other Examples
Other examples of shell scripts that could be used to start services under supervisord can be found at
http://thedjbway.b0llix.net/services.html. These examples are actually for daemontools but the premise
is the same for supervisor.
Another collection of recipes for starting various programs in the foreground is available from
http://smarden.org/runit/runscripts.html.
pidproxy Program
Some processes (like mysqld) ignore signals sent to the actual process which is spawned by supervisord.
Instead, a "special" thread/process is created by these kinds of programs which is responsible for
handling signals. This is problematic because supervisord can only kill a process which it creates
itself. If a process created by supervisord creates its own child processes, supervisord cannot kill
them.
Fortunately, these types of programs typically write a "pidfile" which contains the "special" process'
PID, and is meant to be read and used in order to kill the process. As a workaround for this case, a
special pidproxy program can handle startup of these kinds of processes. The pidproxy program is a small
shim that starts a process, and upon the receipt of a signal, sends the signal to the pid provided in a
pidfile. A sample configuration program entry for a pidproxy-enabled program is provided below.
[program:mysql]
command=/path/to/pidproxy /path/to/pidfile /path/to/mysqld_safe
The pidproxy program is put into your configuration's $BINDIR when supervisor is installed (it is a
"console script").
Subprocess Environment
Subprocesses will inherit the environment of the shell used to start the supervisord program. Several
environment variables will be set by supervisord itself in the child's environment also, including
SUPERVISOR_ENABLED (a flag indicating the process is under supervisor control), SUPERVISOR_PROCESS_NAME
(the config-file-specified process name for this process) and SUPERVISOR_GROUP_NAME (the
config-file-specified process group name for the child process).
These environment variables may be overridden within the [supervisord] section config option named
environment (applies to all subprocesses) or within the per- [program:x] section environment config
option (applies only to the subprocess specified within the [program:x] section). These "environment"
settings are additive. In other words, each subprocess' environment will consist of:
The environment variables set within the shell used to start supervisord...
... added-to/overridden-by ...
... the environment variables set within the environment global
config option ...
... added-to/overridden-by ...
... supervisor-specific environment variables
(SUPERVISOR_ENABLED, SUPERVISOR_PROCESS_NAME, SUPERVISOR_GROUP_NAME) ..
... added-to/overridden-by ...
... the environment variables set within the per-process
"environment" config option.
No shell is executed by supervisord when it runs a subprocess, so environment variables such as USER,
PATH, HOME, SHELL, LOGNAME, etc. are not changed from their defaults or otherwise reassigned. This is
particularly important to note when you are running a program from a supervisord run as root with a user=
stanza in the configuration. Unlike cron, supervisord does not attempt to divine and override
"fundamental" environment variables like USER, PATH, HOME, and LOGNAME when it performs a setuid to the
user defined within the user= program config option. If you need to set environment variables for a
particular program that might otherwise be set by a shell invocation for a particular user, you must do
it explicitly within the environment= program config option. An example of setting these environment
variables is as below.
[program:apache2]
command=/home/chrism/bin/httpd -c "ErrorLog /dev/stdout" -DFOREGROUND
user=chrism
environment=HOME="/home/chrism",USER="chrism"
Process States
A process controlled by supervisord will be in one of the below states at any given time. You may see
these state names in various user interface elements in clients.
STOPPED (0)
The process has been stopped due to a stop request or has never been started.
STARTING (10)
The process is starting due to a start request.
RUNNING (20)
The process is running.
BACKOFF (30)
The process entered the STARTING state but subsequently exited too quickly to move to the RUNNING
state.
STOPPING (40)
The process is stopping due to a stop request.
EXITED (100)
The process exited from the RUNNING state (expectedly or unexpectedly).
FATAL (200)
The process could not be started successfully.
UNKNOWN (1000)
The process is in an unknown state (supervisord programming error).
Each process run under supervisor progresses through these states as per the following directed graph.
[image: Subprocess State Transition Graph] [image] Subprocess State Transition Graph.UNINDENT
A process is in the STOPPED state if it has been stopped adminstratively or if it has never been
started.
When an autorestarting process is in the BACKOFF state, it will be automatically restarted by
supervisord. It will switch between STARTING and BACKOFF states until it becomes evident that it
cannot be started because the number of startretries has exceeded the maximum, at which point it will
transition to the FATAL state. Each start retry will take progressively more time.
When a process is in the EXITED state, it will automatically restart:
• never if its autorestart parameter is set to false.
• unconditionally if its autorestart parameter is set to true.
• conditionally if its autorestart parameter is set to unexpected. If it exited with an exit code that
doesn't match one of the exit codes defined in the exitcodes configuration parameter for the process,
it will be restarted.
A process automatically transitions from EXITED to RUNNING as a result of being configured to autorestart
conditionally or unconditionally. The number of transitions between RUNNING and EXITED is not limited in
any way: it is possible to create a configuration that endlessly restarts an exited process. This is a
feature, not a bug.
An autorestarted process will never be automatically restarted if it ends up in the FATAL state (it must
be manually restarted from this state).
A process transitions into the STOPPING state via an administrative stop request, and will then end up in
the STOPPED state.
A process that cannot be stopped successfully will stay in the STOPPING state forever. This situation
should never be reached during normal operations as it implies that the process did not respond to a
final SIGKILL signal sent to it by supervisor, which is "impossible" under UNIX.
State transitions which always require user action to invoke are these:
FATAL -> STARTING
RUNNING -> STOPPING
State transitions which typically, but not always, require user action to invoke are these, with
exceptions noted:
STOPPED -> STARTING (except at supervisord startup if process is configured to autostart)
EXITED -> STARTING (except if process is configured to autorestart)
All other state transitions are managed by supervisord automatically.
Glossary
daemontools
A process control system by D.J. Bernstein.
launchd
A process control system used by Apple as process 1 under Mac OS X.
runit A process control system.
Superlance
A package which provides various event listener implementations that plug into Supervisor which
can help monitor process memory usage and crash status: http://pypi.python.org/pypi/superlance.
umask Abbreviation of user mask: sets the file mode creation mask of the current process. See
http://en.wikipedia.org/wiki/Umask.
AUTHOR
This man page was created by Orestis Ioannou <orestis@oioannou.com> using the official documentation.
COPYRIGHT
2004-2015, Agendaless Consulting and Contributors
3.2.0 December 10, 2015 SUPERVISORD(1)