Skip to content

Supervisor

Supervisor is a process control system that makes it easy to start, stop, and restart your Vapor app.

Install

Supervisor can be installed through package managers on Linux.

Ubuntu

sudo apt-get update
sudo apt-get install supervisor

CentOS and Amazon Linux

sudo yum install supervisor

Fedora

sudo dnf install supervisor

Configure

Each Vapor app on your server should have its own configuration file. For an example Hello project, the configuration file would be located at /etc/supervisor/conf.d/hello.conf

[program:hello]
command=/home/vapor/hello/.build/release/App serve --env production
directory=/home/vapor/hello/
user=vapor
stdout_logfile=/var/log/supervisor/%(program_name)-stdout.log
stderr_logfile=/var/log/supervisor/%(program_name)-stderr.log

As specified in our configuration file the Hello project is located in the home folder for the user vapor. Make sure directory points to the root directory of your project where the Package.swift file is.

The --env production flag will disable verbose logging.

Environment

You can export variables to your Vapor app with supervisor. For exporting multiple environment values, put them all on one line. Per Supervisor documentation:

Values containing non-alphanumeric characters should be quoted (e.g. KEY="val:123",KEY2="val,456"). Otherwise, quoting the values is optional but recommended.

environment=PORT=8123,ANOTHERVALUE="/something/else"

Exported variables can be used in Vapor using Environment.get

let port = Environment.get("PORT")

Start

You can now load and start your app.

supervisorctl reread
supervisorctl add hello
supervisorctl start hello

Note

The add command may have already started your app.