This repository has been archived on 2024-04-08. You can view files and clone it, but cannot push or open issues or pull requests.
dagger/docs/use-cases/1211-go-docker-swarm.md
Gerhard Lazu 3747c6e5c4
First pass at the Go on Docker Swarm doc page
There are a few more things to do before we can finish this, see the
comments in the doc. The most important item is to switch the Dagger
config to Europa. That is actually one of the next steps.

Sharing this early so that we start collaborating. Pushing to a branch
in the dagger org so that we can work on it together (personal
repositories make it more difficult).

Signed-off-by: Gerhard Lazu <gerhard@lazu.co.uk>
2022-02-11 15:35:24 +00:00

102 lines
2.7 KiB
Markdown

---
slug: /1211/go-docker-swarm
displayed_sidebar: europaSidebar
---
# Go on Docker Swarm
> TODO: particubes.com screenshot
[Particubes](https://particubes.com) is a platform dedicated to voxel games, which are games made out of little cubes (like Minecraft).
The team consists of 10 developers that like to keep things simple.
Particubes chose Dagger because it was the easiest way to integrate with their Docker Swarm production setup.
Every commit to the main branch gets deployed straight to [particubes.com](https://particubes.com) with Dagger running in GitHub Actions.
The Dagger Universe made it very easy for to build this pipeline.
`docker.#Build`, `docker.#Push` and `docker.#Command` was all that it took.
:::danger
TODO: this config is pre-Europa, the next step is to convert it to Europa.
:::
This is the entire Particubes Dagger plan:
```cue
package particubes
import (
"alpha.dagger.io/dagger"
"alpha.dagger.io/docker"
)
repo: dagger.#Input & {dagger.#Artifact}
swarmSSH: {
user: dagger.#Input & {*"ubuntu" | string}
host: dagger.#Input & {string}
key: dagger.#Input & {dagger.#Secret}
}
docs: {
containerImageName: dagger.#Input & {string}
containerImageTag: dagger.#Input & {*"latest" | string}
// TODO: write the GIT_SHA into a static /git_sha.txt
buildContainerImage: docker.#Build & {
source: repo
}
// TODO:
// - [ ] bootContainer
// - [ ] checkHttpResponse
// - [ ] stopContainer
publishContainerImage: docker.#Push & {
"target": "\(containerImageName):\(containerImageTag)"
source: buildContainerImage
}
deployContainerImage: docker.#Command & {
ssh: swarmSSH
command: "docker service update --image registry.particubes.com/lua-docs:$IMAGE_REF lua-docs"
env: {
"IMAGE_REF": publishContainerImage.ref
}
}
// TODO: // check that the expected GIT_SHA is running in production
// checkHttpResponse /git_sha.txt
}
```
You can find [the original pipeline](https://github.com/voxowl/particubes/blob/b698777465c02462296de37087dd3c341c29df92/lua-docs/docs.cue) in the Particubes GitHub repository.
Anyone on the Particubes team can run this pipeline locally using `dagger up`.
It also runs in GitHub Actions on every commit using the following config:
```yaml
name: Dagger/docs.particubes.com
on:
push:
branches: [ master ]
jobs:
deploy:
runs-on: ubuntu-latest
steps:
- name: Checkout code
uses: actions/checkout@v2
with:
lfs: true
- name: Dagger
uses: dagger/dagger-action@v1
with:
age-key: ${{ secrets.DAGGER_AGE_KEY }}
args: up -e docs
```
### What comes next for particubes.com?
We don't know but we would like find out 😀