Skip to content

dyersituations/catdocker

Repository files navigation

CatDocker

Hosting for the CatCMS project using Docker Compose.

Project Setup

The steps below rely on a Digital Ocean droplet, Windows machine running WSL, and deployment via GitHub Actions.

Server

ssh dockeruser@$IP_ADDRESS
ssh-keygen
ssh-keyscan -t rsa github.com >> ~/.ssh/known_hosts
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys2
chmod 700 ~/.ssh/authorized_keys && chmod 640 ~/.ssh/authorized_keys2
cat ~/.ssh/id_rsa
# Copy to GitHub secret DIGITAL_OCEAN_KEY
  • Run build-and-deploy.yml GitHub Action with domain as proxy

Local Setup

Add Site

  • Create folder for new domain in catdocker repo
  • Copy docker-compose.yml
  • Copy docker-compose.override.yml
  • Change values to match new domain

Utilities

Random helpful scripts for server management.

Restart Droplet

  • Toggle on/off in DigitalOcean dashboard
  • Run build-and-deploy.yml GitHub Action for each domain
proxy
annfleming
caseydyer

Backup Site

ssh root@$IP_ADDRESS
docker container ls
docker cp $CONTAINER_NAME:/var/www backup
# Exit SSH
exit
cd ~/git
sudo scp -r [email protected]:backup backup
ssh root@$IP_ADDRESS
rm -rf backup

Connect to Container

docker container ls
docker exec -it $CONTAINER_NAME bash

View Container Logs

docker container ls
docker logs -f $CONTAINER_NAME

Reset Docker

docker rm -vf $(docker ps -a -q)
docker rmi -f $(docker images -a -q)
docker volume prune
docker network prune
docker system prune

Reset/Reconnect SSH

# Reset password via DigitalOcean droplet settings
# Open droplet recovery console

# Enable password auth
sudo nano /etc/ssh/sshd_config
# Change "PasswordAuthentication yes"

# Delete old keys
nano ~/.ssh/authorized_keys

# Restart SSH
sudo service sshd restart

# Create SSH key locally
ssh-keygen

# Add RSA key to DigitalOcean security settings and delete old keys

# Copy SSH from local machine
ssh-copy-id root@$IP_ADDRESS

# SSH from local machine
ssh root@$IP_ADDRESS

# From recovery console again
sudo nano /etc/ssh/sshd_config
# Change "PasswordAuthentication no"

sudo service sshd restart

Old Manual Steps

These steps were used before GitHub Actions were utilized.

Build Site

  • Ensure domain folder has .env
  RAILS_ENV=production
  SECRET_KEY_BASE=${openssl rand -hex 64}
  • Run the following commands
cd $REPO_ROOT_FOLDER
# Only if needed
git submodule init
git submodule update --recursive --remote
cd $REPO_DOMAIN_FOLDER
sudo docker compose build --no-cache
sudo docker login
sudo docker compose push

New Site Deployment

ssh root@$IP_ADDRESS
mkdir /home/dockeruser/$DOMAIN
scp docker-compose.yml root@$IP_ADDRESS:/home/dockeruser/$DOMAIN
docker-compose up -d

Update Site

ssh root@$IP_ADDRESS
cd /home/dockeruser/$DOMAIN
# Pulls new image, recreates container, runs migrations
docker-compose pull && docker-compose up -d

Restart Droplet

  • Toggle on/off in DigitalOcean dashboard
  • Start applications
ssh root@$IP_ADDRESS
cd /home/dockeruser/proxy
docker-compose up -d
# For each domain
cd /home/dockeruser/$DOMAIN
docker-compose up -d

About

Docker hosting for CatCMS.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published