The first station for every request is a nginx reverse proxy (config is found in nginx-main-config/default
).
Every service that is running on the server (except for the nginx proxy) is listed in docker-compose.yml
, which is a definition file for Docker Compose. Most share a common mysql service running in one docker container (maindb
).
Each of those is accessible via a port, starting from 8000 and incrementing. The nginx proxy forwards proper paths to those ports, e.g. /klub/zeitung
to localhost:8002
.
TODO Auth
Central point for visitors is the frame
service, that displays the navigation top bar containing links to other services (e.g. FSR or club sites) or embeds them directly (e.g. etherpad or 120/180).
All static pages are served from frame/static
and selected via frame/index.php
.
frame
: The PHP Code for the landing page and all static pages.nginx-main-conf
: nginx config file that is symlinked to/etc/nginx/sites-enabled
. Home of all forwards from user visible links to ports of services.wordpress
: Slightly modified docker image for wordpress (allows to modify path at which the wordpress installation is run).docker-compose.yml
: Definitions of all services running on the server.docker-common.env
: Helper file for the .yml, containing env var definitions shared by services.
- Create a copy of a Wordpress site in
docker-common.yml
- Adjust service name,
WORDPRESS_PATH
andWORDPRESS_DB_NAME
- Assign max of all port numbers plus one to port
- In
nginx-main-conf/default
, add aproxy_pass
with the set path and port. - Update docker-compose (
docker-compose up -d {your service's name}
) - Reload nginx (
nginx -s reload
)
- Open
docker-common.yml
. - Locate the
frame
service and add a new LINK or CLUB item. Avoid duplicate numbers. Items are ordered in ascending order of their number suffix. - Restart the
frame
service (docker-compose up -d frame
)
- Create a php/html page in
frame/static/
. - Add another
case '/your-path'
inframe/index.php
that includes your file.
All static resources can be placed in the frame/static-files
folder, from which they wil be directly accessible.
Container data is stored in named docker volumes. You can backup that using the backup.sh
-script:
sudo ./backup.sh path-to-backups
The script backups the volumes in subdirectories into the specified backup directory.
git config --global url.https://github.com/.insteadOf git@github.com:
as you probably don't have an ssh key on the server (for the submodules)git clone --recursive https://github.com/HopelessProgrammingInterns/hpi-websiteklub-docker
- Absolutely make sure the passwords in
docker-common.env
are changed on the server - Adjust the path in
nginx-main-conf/default
to point to the location of thedocker-compose.yml
script - Setup a nginx that imports the
nginx-main-conf/default
script
- QuoteDB
- Studix
- 120
- 180
- Etherpad
- Sport Reservierungen
- Filmklub Blog (Last Update: Jul 2014)
- Zeitungsklub Blog (neu)
- Verlinkung Connect Klub Blog
- Geocaching
- Auth: Basic Auth via HPI Kerberos
- FSR kriegt übersichtsseite, navbar
- Verlinkung Redmine
- forbid access to all files in
frame/*/*
except for navbar