Skip to content

Docker

  • traefik as reverse proxy and tls termination
  • nginx for serving static content
  • canary-cd for deploying projects and static pages

GitHub forks

example folder structure
├── compose.yml
├── data
│   ├── database.sqlite
│   ├── dynamic
│   │   └── pages.example.yml
│   ├── pages
│   │ └── pages.example.com
│   │     └── index.html
│   └── repositories
│       └── my-project
├── nginx-static.conf
├── ssl
│   └── acme-letsencrypt.json
└── traefik.yml

Setup Docker

# Add Docker's official GPG key:
sudo apt-get update
sudo apt-get install ca-certificates curl
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc

# Add the repository to Apt sources:
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
  $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
  sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
- Setup Docker on Ubuntu

Setup Services

Clone example repository

git clone https://github.com/rehborn/canary-deploy /srv/canary

create config

cd /srv/canary
cat <<EOF>.env
CANARY_HOST=canary.example.com
CANARY_SALT=$(openssl rand -base64 32) 
EOF
.env
CANARY_HOST=
CANARY_SALT=

create network

docker network create traefik

start service

docker compose up -d

grep API key

docker compose logs|grep API_KEY

logging

docker compose logs -f

verify setup

ss -tlnp|grep -E ':80|:443'
Was this page helpful?