From 3ed50744091666efba5e38dcf519c814321d254a Mon Sep 17 00:00:00 2001 From: Oliver Davies Date: Fri, 12 Aug 2022 23:57:19 +0100 Subject: [PATCH] docs: my first daily email article --- website/app/config/sculpin_kernel.yml | 2 + .../git-worktrees-docker-compose.md | 74 +++++++++++++++++++ website/source/_layouts/daily_email.html.twig | 1 + website/source/_pages/daily.html.twig | 16 ++++ 4 files changed, 93 insertions(+) create mode 100644 website/source/_daily_emails/git-worktrees-docker-compose.md create mode 100644 website/source/_layouts/daily_email.html.twig create mode 100644 website/source/_pages/daily.html.twig diff --git a/website/app/config/sculpin_kernel.yml b/website/app/config/sculpin_kernel.yml index 4456c609..942072bd 100644 --- a/website/app/config/sculpin_kernel.yml +++ b/website/app/config/sculpin_kernel.yml @@ -1,4 +1,6 @@ sculpin_content_types: + daily_emails: + permalink: archives/:year/:month/:day/:basename/ pages: permalink: /:basename/ posts: diff --git a/website/source/_daily_emails/git-worktrees-docker-compose.md b/website/source/_daily_emails/git-worktrees-docker-compose.md new file mode 100644 index 00000000..30cb6eed --- /dev/null +++ b/website/source/_daily_emails/git-worktrees-docker-compose.md @@ -0,0 +1,74 @@ +--- +title: Git Worktrees and Docker Compose +date: 2022-08-12 +--- + +I've recently started trialing Git worktrees again as part of my development workflow. + +If you are unfamiliar with Git worktrees, they allow you to have muliple branches of a repository checked out at the same time in different directories. + +For example, this is what I see within my local checkout of my website repository: + +``` +. +├── config +├── HEAD +├── main +│   ├── ansible +│   ├── nginx +│   ├── README.md +│   └── website +├── new-post +│   ├── ansible +│   ├── nginx +│   ├── README.md +│   └── website +├── objects +│   ├── info +│   └── pack +├── packed-refs +├── refs +│   ├── heads +│   └── tags +└── worktrees + ├── main + └── new-post +``` + +The first thing that you'll notice is, because it's a bare clone, it looks a little different to a what you usually see in a Git repository. + +Each worktree has it's own directory, so my "main" branch inside the `main` directory. + +If I need to work on a different branch, such as `new-post`, then I can create a new worktree, move into that directory and start working. I don't need to commit or stash any in-progress work and switch branches. + +## Complications with Docker Compose + +I use Docker and Docker Compose for my projects, and this caused some issues for me the last time that I tried using worktrees. + +By default, Docker Compose will use the name of the directory that the Compose file is in to name its containers. If the directory name is "oliverdavies-uk", then the containers will be `oliverdavies-uk-web_1`, `oliverdavies-uk-db_1` etc. + +This doesn't work so well if the directory is a worktree called "main" or "master" as you'll have containers called `main_web_1` or `master_db_1`. + +The way to solve this is to use the `COMPOSE_PROJECT_NAME` environment variable. + +If you prefix Docker Compose commands with `COMPOSE_PROJECT_NAME=your-project`, or add it to an `.env` file (Docker Compose will load this automatically), then this will override the prefix in the container names to be `your-project-{service}`. + +## Container names per worktree + +Whilst you could use the same Compose project name within all of your worktrees, I prefer to include the worktree name as a suffix - something like `my-project-main` or `my-project-staging` - and keep these stored in an `.env` file in each worktree's directory. + +As each worktree now has unique container names, I can have multiple instances of a project running at the same time, and each worktree will have it's own separate data - meaning that I can make changes and test something in one worktree without affecting any others. + +You can also use the `COMPOSE_PROJECT_NAME` variable inside Docker Compose files. + +For example, if you use Traefik and needed to override the host URL for a service, the string will be interpolated and the project name would be injected as you'd expect. + +```yaml +labels: + - "traefik.http.routers.${COMPOSE_PROJECT_NAME}.rule=Host( + `${COMPOSE_PROJECT_NAME}.docker.localhost`, + `admin.${COMPOSE_PROJECT_NAME}.docker.localhost` + )" +``` + +This means that Traefik would continue to use a different URL for each worktree without you needing to make any changes to your Docker Compose file. diff --git a/website/source/_layouts/daily_email.html.twig b/website/source/_layouts/daily_email.html.twig new file mode 100644 index 00000000..a41ae1fe --- /dev/null +++ b/website/source/_layouts/daily_email.html.twig @@ -0,0 +1 @@ +{% extends "default" %} diff --git a/website/source/_pages/daily.html.twig b/website/source/_pages/daily.html.twig new file mode 100644 index 00000000..f5c9d631 --- /dev/null +++ b/website/source/_pages/daily.html.twig @@ -0,0 +1,16 @@ +--- +title: Daily emails +use: + - daily_emails +--- + +