-
Notifications
You must be signed in to change notification settings - Fork 108
Production Environment for the 2017 Website
shunghsiyu edited this page Apr 26, 2019
·
1 revision
The following describes how to run the server in production using Docker.
It assumes that:
- A database has already been properly setup
- A reverse proxy is configured to forward requests to the server (strictly speaking the server will work without a reverse proxy, but performance will be awful)
How to fulfill the above prerequisite is beyond the scope of this document.
- Git 1.8+
- Docker 17.09+ (since we use
--chown
flag in the COPY directive)
After cloning this repository, and checking-out the correct branch, cd
into the directory and run
docker build -f Dockerfile -t pycontw-2017 .
There are four configurations that must be set when running the container.
-
SECRET_KEY
is used to provide cryptographic signing, refer to src/pycontw2016/settings/local.sample.env on how to generate secret key -
DATABASE_URL
specifies how to connect to the database (in the URL form e.g.postgres://username:password@host_or_ip:5432/database_name
) -
EMAIL_URL
specifies how to connect to the mail server (e.g.smtp+tls://username:password@host_or_ip:25
) -
DSN_URL
specify how to connect to Sentry error reporting service (e.g.https://key@sentry.io/project
), please refer to Sentry's documentation on how to obtain Data Source Name - (optional)
GA_TRACK_ID
specify the Google Analytics ID for the website - (optional)
SLACK_WEBHOOK_URL
For demonstration purpose, we'll use dummy values for the above container environment variables from here on, please change them to according to your environment.
Generate the static assets (e.g. javascript, CSS)
docker run --rm \
-e DJANGO_SETTINGS_MODULE='pycontw2016.settings.production.pycontw2017' \
-e SECRET_KEY='not_really_a_secret' \
-e DATABASE_URL='postgres://username:password@host_or_ip:5432/database_name' \
-e EMAIL_URL='smtp+tls://username:password@host_or_ip:25' \
-e DSN_URL='https://key@sentry.io/project' \
--mount type=volume,src=pycontw-2017-media,dst=/usr/local/app/src/media \
--mount type=volume,src=pycontw-2017-static,dst=/usr/local/app/src/assets \
pycontw-2017 \
python3 manage.py collectstatic --no-input
Migrate the database to the latest schema
docker run --rm \
-e DJANGO_SETTINGS_MODULE='pycontw2016.settings.production.pycontw2017' \
-e SECRET_KEY='not_really_a_secret' \
-e DATABASE_URL='postgres://username:password@host_or_ip:5432/database_name' \
-e EMAIL_URL='smtp+tls://username:password@host_or_ip:25' \
-e DSN_URL='https://key@sentry.io/project' \
--mount type=volume,src=pycontw-2017-media,dst=/usr/local/app/src/media \
--mount type=volume,src=pycontw-2017-static,dst=/usr/local/app/src/assets \
pycontw-2017 \
python3 manage.py migrate
Run the production server container with automatic restart across failures and reboots
docker run \
--name=pycontw-2017 \
--detach \
--restart=always \
-e DJANGO_SETTINGS_MODULE='pycontw2016.settings.production.pycontw2017' \
-e SECRET_KEY='not_really_a_secret' \
-e DATABASE_URL='postgres://username:password@host_or_ip:5432/database_name' \
-e EMAIL_URL='smtp+tls://username:password@host_or_ip:25' \
-e DSN_URL='https://key@sentry.io/project' \
--mount type=volume,src=pycontw-2017-media,dst=/usr/local/app/src/media \
--mount type=volume,src=pycontw-2017-static,dst=/usr/local/app/src/assets \
pycontw-2017