example-deployable-app/README.md

40 lines
1.9 KiB
Markdown

Example Dockerised, Terraformed application deployment onto docker on bare metal
===============================================================================
We're gonna run Quassel on bare metal in the most low-effort and high-reward enterprisey way possible.
Why? Because we can.
## Pre-requisites
We're gonna need some tools:
* OpenTofu, the replacement for Terraform since Hashicorp changed the licence terms: https://opentofu.org/docs/intro/install/.
* As Tofu is a drop in replacement for Terraform, you can use Terraform if you prefer, and I'll refer to them interchangeably.
* Nektos/Act so we can run our GitHub Actions locally. https://github.com/nektos/act/releases
## What have we got going on in here?
The main players:
* database.tf - Configures our Quassel instances Postgres
* quassel.tf - Configures our Quassel instance itself
The bit-actors:
* docker.tf - Configures the Docker Provider for Tofu
* inputs.tf - Where inputs to this deployment are defined and may have defaults set
* outputs.tf - Where outputs from this deployment are defined, which will be output when we run `tofu apply` or `tofu outputs`
* terraform.tf - Telling Terraform/ToFu what packages we need to run this deployment
* .terraform.lock.hcl - Lock file for Terraform/ToFu, this is here to ensure that we're all using the same versions of the same packages
* terraform.tfvars - Where we may set the variables defined in inputs.tf
## What happens when we run this?
When we run `tofu apply`:
* Tofu will create a Docker network for our Quassel instance
* Tofu will create a Postgres instance for our Quassel instance
* Tofu will compile our Quassel instance image from the Dockerfile in the quassel directory
* Tofu will create a Quassel instance using that image
* Tofu will output the IP address of the Quassel instance and postgres instance
## How do we run this?
Did you give `tofu apply` a go yet?
## What we're gonna end up with:
`DIAGRAM GOES HERE`