-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
'modified: docs/index.md // new: docs/how-to/h-set-up/h-deploy-terraf…
…orm.md' (#597) Co-authored-by: discourse-gatekeeper-docs-bot <[email protected]>
- Loading branch information
1 parent
d08b26a
commit f4e0b7a
Showing
2 changed files
with
168 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,167 @@ | ||
# How to deploy using Terraform | ||
|
||
[Terraform](https://www.terraform.io/) is an infrastructure automation tool to provision and manage resources in clouds or data centers. To deploy Charmed PostgreSQL K8s using Terraform and Juju, you can use the [Juju Terraform Provider](https://registry.terraform.io/providers/juju/juju/latest). | ||
|
||
The easiest way is to start from [these examples of terraform modules](https://github.com/canonical/terraform-modules) prepared by Canonical. This page will guide you through a deployment using an example module for PostgreSQL on Kubernetes. | ||
|
||
For an in-depth introduction to the Juju Terraform Provider, read [this Discourse post](https://discourse.charmhub.io/t/6939). | ||
|
||
[note] | ||
**Note**: Storage support was added in [Juju Terraform Provider version 0.13+](https://github.com/juju/terraform-provider-juju/releases/tag/v0.13.0). | ||
[/note] | ||
|
||
## Summary | ||
* [Install Terraform tooling](#install-terraform-tooling) | ||
* [Verify the deployment](#verify-the-deployment) | ||
* [Apply the deployment](#apply-the-deployment) | ||
* [Check deployment status](#check-deployment-status) | ||
* [Clean up](#clean-up) | ||
--- | ||
|
||
## Install Terraform tooling | ||
|
||
This guide assumes Juju is installed and you have a K8s controller already bootstrapped. For more information, check the [Set up the environment](/t/9709) tutorial page. | ||
|
||
Let's install Terraform Provider and example modules: | ||
```shell | ||
sudo snap install terraform --classic | ||
``` | ||
Switch to the K8s provider and create a new model: | ||
```shell | ||
juju switch microk8s | ||
juju add-model my-model | ||
``` | ||
Clone examples and navigate to the PostgreSQL machine module: | ||
```shell | ||
git clone https://github.com/canonical/terraform-modules.git | ||
cd terraform-modules/modules/k8s/postgresql | ||
``` | ||
|
||
Initialise the Juju Terraform Provider: | ||
```shell | ||
terraform init | ||
``` | ||
|
||
## Verify the deployment | ||
|
||
Open the `main.tf` file to see the brief contents of the Terraform module: | ||
|
||
```tf | ||
resource "juju_application" "k8s_postgresql" { | ||
name = var.postgresql_application_name | ||
model = var.juju_model_name | ||
trust = true | ||
charm { | ||
name = "postgresql-k8s" | ||
channel = var.postgresql_charm_channel | ||
} | ||
units = 1 | ||
} | ||
``` | ||
|
||
Run `terraform plan` to get a preview of the changes that will be made: | ||
|
||
```shell | ||
terraform plan -var "juju_model_name=my-model" | ||
``` | ||
|
||
## Apply the deployment | ||
|
||
If everything looks correct, deploy the resources (skip the approval): | ||
|
||
```shell | ||
terraform apply -auto-approve -var "juju_model_name=my-model" | ||
``` | ||
|
||
## Check deployment status | ||
|
||
Check the deployment status with | ||
|
||
```shell | ||
juju status --model k8s:my-model --watch 1s | ||
``` | ||
|
||
Sample output: | ||
|
||
```shell | ||
Model Controller Cloud/Region Version SLA Timestamp | ||
my-model k8s microk8s/localhost 3.5.3 unsupported 12:09:38Z | ||
|
||
App Version Status Scale Charm Channel Rev Address Exposed Message | ||
postgresql-k8s 14.11 active 1 postgresql-k8s 14/stable 281 10.152.183.137 no | ||
|
||
Unit Workload Agent Address Ports Message | ||
postgresql-k8s/0* active idle 10.1.77.74 Primary | ||
|
||
``` | ||
|
||
Continue to operate the charm as usual from here or apply further Terraform changes. | ||
|
||
## Clean up | ||
|
||
To keep the house clean, remove the newly deployed Charmed PostgreSQL by running | ||
```shell | ||
terraform destroy -var "juju_model_name=my-model" | ||
``` | ||
|
||
Sample output: | ||
```shell | ||
juju_application.k8s_postgresql: Refreshing state... [id=my-model:postgresql-k8s] | ||
|
||
Terraform used the selected providers to generate the following execution plan. Resource actions are indicated with the following symbols: | ||
- destroy | ||
|
||
Terraform will perform the following actions: | ||
|
||
# juju_application.k8s_postgresql will be destroyed | ||
- resource "juju_application" "k8s_postgresql" { | ||
- constraints = "arch=amd64" -> null | ||
- id = "my-model:postgresql-k8s" -> null | ||
- model = "my-model" -> null | ||
- name = "postgresql-k8s" -> null | ||
- placement = "" -> null | ||
- storage = [ | ||
- { | ||
- count = 1 -> null | ||
- label = "pgdata" -> null | ||
- pool = "kubernetes" -> null | ||
- size = "1G" -> null | ||
}, | ||
] -> null | ||
- trust = true -> null | ||
- units = 1 -> null | ||
|
||
- charm { | ||
- base = "[email protected]" -> null | ||
- channel = "14/stable" -> null | ||
- name = "postgresql-k8s" -> null | ||
- revision = 281 -> null | ||
- series = "jammy" -> null | ||
} | ||
} | ||
|
||
Plan: 0 to add, 0 to change, 1 to destroy. | ||
|
||
Changes to Outputs: | ||
- application_name = "postgresql-k8s" -> null | ||
|
||
Do you really want to destroy all resources? | ||
Terraform will destroy all your managed infrastructure, as shown above. | ||
There is no undo. Only 'yes' will be accepted to confirm. | ||
|
||
Enter a value: yes | ||
|
||
juju_application.k8s_postgresql: Destroying... [id=my-model:postgresql-k8s] | ||
juju_application.k8s_postgresql: Destruction complete after 0s | ||
|
||
Destroy complete! Resources: 1 destroyed. | ||
``` | ||
--- | ||
|
||
[note] | ||
For more examples of Terraform modules for K8s, see the other directories in the [`terraform-modules` repository](https://github.com/canonical/terraform-modules/tree/main/modules/k8s). | ||
[/note] | ||
|
||
Feel free to [contact us](/t/11863) if you have any question and [collaborate with us on GitHub](https://github.com/canonical/terraform-modules)! |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters