Skip to content

Commit

Permalink
Finish writing up guide for running Concourse with Docker Compose
Browse files Browse the repository at this point in the history
Signed-off-by: Taylor Silva <[email protected]>
  • Loading branch information
taylorsilva committed Jul 7, 2024
1 parent 737e15d commit ace6590
Show file tree
Hide file tree
Showing 2 changed files with 191 additions and 14 deletions.
160 changes: 160 additions & 0 deletions lit/docs/install/docker-compose.lit
Original file line number Diff line number Diff line change
@@ -1,3 +1,163 @@
\title{\aux{Install Concourse with} Docker Compose}{install-docker-compose}

\use-plugin{concourse-docs}

This guide will show you how to install Concourse on any Linux system
using \link{Docker Compose}{https://docs.docker.com/compose/}.

This guide makes the following assumptions:
\ordered-list{
The host system has Docker installed already.
}{
You have a PostgreSQL database running somewhere already. You created a
database called \code{concourse} and created a user for Concourse to
authenticate as.
}{
You have generated the necessary
\reference{generating-keys}{encryption Keys}.
}{
The host system the Web node will be running on is exposed to the
internet and can therefore accept inbound traffic on port \code{443}.
}{
The Web and Worker node are being installed on separate servers and you
will figure out networking between the two servers. The Web node needs
to accept ingress traffic on the TSA port (default is port \code{2222})
from the Worker node(s).
}


\section{
\title{Setup Web Node}{docker-web}

You can do the following from any directory on your system. This guide
will assume all work is done in \code{~/concourse}.

Create a directory called \code{keys} (\code{~/concourse/keys}). Place
the following encryption keys inside the new directory:
\list{
\code{session_signing_key}
}{
\code{tsa_host_key}
}{
\code{worker_key.pub}
}

Next, create a \code{docker-compose.yml} file
(\code{~/concourse/docker-compose.yml}) with the following content:

\codeblock{yaml}{{{
services:
web:
image: docker.io/concourse/concourse:latest
command: web
restart: "unless-stopped"
ports:
- "443:8080"
- "2222:2222"
volumes:
- ~/concourse/keys:/concourse-keys:ro
environment:
CONCOURSE_EXTERNAL_URL: https://ci.example.com
CONCOURSE_ENABLE_LETS_ENCRYPT: "true"
CONCOURSE_SESSION_SIGNING_KEY: /concourse-keys/session_signing_key
CONCOURSE_TSA_AUTHORIZED_KEYS: /concourse-keys/worker_key.pub
CONCOURSE_TSA_HOST_KEY: /concourse-keys/tsa_host_key
CONCOURSE_POSTGRES_HOST: <psql hostname>
CONCOURSE_POSTGRES_USER: <psql user>
CONCOURSE_POSTGRES_PASSWORD: <psql password>
CONCOURSE_POSTGRES_DATABASE: concourse
CONCOURSE_ADD_LOCAL_USER: test:test
CONCOURSE_MAIN_TEAM_LOCAL_USER: test
CONCOURSE_CLUSTER_NAME: Concourse
CONCOURSE_ENABLE_ACROSS_STEP: "true"
CONCOURSE_ENABLE_REDACT_SECRETS: "true"
CONCOURSE_ENABLE_PIPELINE_INSTANCES: "true"
CONCOURSE_ENABLE_CACHE_STREAMED_VOLUMES: "true"
logging:
driver: local
options:
max-size: "100m"
}}}

\aside{
The above file configues the web node with
\reference{local-auth}{local user authentication} with the username
and password set to \code{test}. You will probably want to configure
your web node with one of the other
\reference{configuring-auth}{authentication providers} and remove the
\code{*_LOCAL_USER} environment variables.
}

You can start the Web node by running:

\codeblock{bash}{{{
docker compose up -d
}}}

You should then be able to access Concourse from the
\code{CONCOURSE_EXTERNAL_URL} you specified.

If you're using local authentication you can login using the
\reference{fly}.

\codeblock{bash}{{{
fly -t ci -c https://ci.example.com -u test -p test
}}}
}

\section{
\title{Setup Worker Node}{docker-worker}

You can do the following from any directory on your system. This guide
will assume all work is done in \code{~/concourse}.

Create a directory called \code{keys} (\code{~/concourse/keys}). Place
the following encryption keys inside the new directory:
\list{
\code{tsa_host_key.pub}
}{
\code{worker_key}
}

Next, create a \code{docker-compose.yml} file
(\code{~/concourse/docker-compose.yml}) with the following content:

\codeblock{yaml}{{{
services:
worker:
image: docker.io/concourse/concourse:latest
command: worker
privileged: true
restart: "unless-stopped"
stop_signal: SIGUSR2
volumes:
- ~/concourse/keys:/concourse-keys:ro
environment:
CONCOURSE_NAME: worker-01
CONCOURSE_RUNTIME: containerd
CONCOURSE_BAGGAGECLAIM_DRIVER: overlay
CONCOURSE_TSA_PUBLIC_KEY: /concourse-keys/tsa_host_key.pub
CONCOURSE_TSA_WORKER_PRIVATE_KEY: /concourse-keys/worker_key
CONCOURSE_TSA_HOST: <web-hostname-or-ip>:2222
logging:
driver: local
options:
max-size: "100m"
}}}

\aside{
If your pipelines are having issues with DNS resolution please read
\reference{worker-troubleshoot-dns}{this section}.
}

You can start the Worker node by running:

\codeblock{bash}{{{
docker compose up -d
}}}

Using the \reference{fly} you should be able to see the worker successfully
connected to the Web node by running \code{fly workers}.

Congratulations, you've successfully deployed a Concourse cluster!
}
45 changes: 31 additions & 14 deletions lit/docs/install/systemd.lit
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,19 @@ running \link{Systemd}{https://github.com/systemd/systemd}.
This guide makes the following assumptions:
\ordered-list{
You have a PostgreSQL database running somewhere already. You created a
database called \code{concourse}. You've created a user for Concourse to
database called \code{concourse} and created a user for Concourse to
authenticate as.
}{
You have generated the necessary
\reference{generating-keys}{encryption Keys}.
}{
The Web node will be directly exposed to the internet and can therefore
accept inbound traffic on port 443.
accept inbound traffic on port \code{443}.
}{
The Web and Worker node are being installed on separate servers and you
will figure out networking between the two servers.
will figure out networking between the two servers. The Web node needs
to accept ingress traffic on the TSA port (default is port \code{2222})
from the Worker node(s).
}

\section{
Expand Down Expand Up @@ -49,7 +51,7 @@ This guide makes the following assumptions:
}

\section{
\title{Web Node}{systemd-web}
\title{Setup Web Node}{systemd-web}
First lets create a new user and group for the Web node to run as:

\codeblock{bash}{{{
Expand Down Expand Up @@ -102,9 +104,22 @@ This guide makes the following assumptions:
CONCOURSE_TSA_AUTHORIZED_KEYS=/usr/local/concourse/keys/worker_key.pub
CONCOURSE_CLUSTER_NAME=Concourse
CONCOURSE_MAIN_TEAM_LOCAL_USER=local
CONCOURSE_ADD_LOCAL_USER=local:local
CONCOURSE_ADD_LOCAL_USER=test:test
CONCOURSE_ENABLE_ACROSS_STEP=true
CONCOURSE_ENABLE_REDACT_SECRETS=true
CONCOURSE_ENABLE_PIPELINE_INSTANCES=true
CONCOURSE_ENABLE_CACHE_STREAMED_VOLUMES=true
}}}

\aside{
The above file configues the web node with
\reference{local-auth}{local user authentication} with the username
and password set to \code{test}. You will probably want to configure
your web node with one of the other
\reference{configuring-auth}{authentication providers} and remove the
\code{*_LOCAL_USER} environment variables.
}

Set the file permissions to read-only:
\codeblock{bash}{{{
chmod 0444 web.env
Expand Down Expand Up @@ -154,10 +169,19 @@ This guide makes the following assumptions:
journalctl -u concourse-web
}}}

You should then be able to access Concourse from the
\code{CONCOURSE_EXTERNAL_URL} you specified.

If you're using local authentication you can login using the
\reference{fly}.

\codeblock{bash}{{{
fly -t ci -c https://ci.example.com -u test -p test
}}}
}

\section{
\title{Worker Node}{systemd-worker}
\title{Setup Worker Node}{systemd-worker}
The Worker has to run as root so there is no user to create. We can go
straight to configuring the Worker.

Expand All @@ -178,13 +202,6 @@ This guide makes the following assumptions:
options run \code{concourse worker --help} and read more about
\reference{worker-node}{running a worker node}.

Change the following values:
\list{
\code{CONCOURSE_TSA_HOST} - This should be set to a hostname or IP that the
worker can use to reach the Web node, including the TSA port, which defaults
to port 2222.
}

\codeblock{}{{{
PATH=/usr/local/concourse/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
CONCOURSE_NAME=worker-01
Expand All @@ -197,7 +214,7 @@ This guide makes the following assumptions:
}}}

\aside{
If you're having issues with DNS resolution please read
If your pipelines are having issues with DNS resolution please read
\reference{worker-troubleshoot-dns}{this section}.
}

Expand Down

0 comments on commit ace6590

Please sign in to comment.