The Terraform provider for Aiven.io, an open source data platform as a service.
See the official documentation to learn about all the possible services and resources.
Recreating stateful services with Terraform will possibly delete the service and all its data before creating it again. Whenever the Terraform plan indicates that a service will be deleted or replaced, a catastrophic action is possibly about to happen.
Some properties, like project and the resource name, cannot be changed and it will trigger a resource replacement.
To avoid any issues, please set the termination_protection
property to true
on all production services, it will prevent Terraform to remove the service until the flag is set back to false
again. While it prevents a service to be deleted, any logical databases, topics or other configurations may be removed even when this section is enabled. Be very careful!
- Signup for Aiven
- Get your authentication token and project name
- Create a file named
main.tf
with the content below:
terraform {
required_providers {
aiven = {
source = "aiven/aiven"
version = "2.1.12" # check out the latest version in the release section
}
}
}
provider "aiven" {
api_token = "your-api-token"
}
resource "aiven_pg" "postgresql" {
project = "your-project-name"
service_name = "postgresql"
cloud_name = "google-europe-west3"
plan = "startup-4"
termination_protection = true
}
output "postgresql_service_uri" {
value = aiven_pg.postgresql.service_uri
sensitive = true
}
- Run in your terminal:
$ terraform init
$ terraform plan
$ terraform apply
$ psql "$(terraform output -raw postgresql_service_uri)"
Voilà, a PostgreSQL database.
$ git clone https://github.com/aiven/terraform-provider-aiven.git
Run the command below. It will generate the binaries under the plugins/$OS_$ARCH
folder.
$ make bins
Run the tests with the command below:
$ make test
Run the acceptance tests with the commands below:
$ export AIVEN_TOKEN="your-token"
$ export AIVEN_PROJECT_NAME="your-project-name"
$ make testacc
# or run a specific acceptance test
$ make testacc TESTARGS='-run=TestAccAiven_kafka'
Acceptance tests create real resources, and often cost money to run.
For information about writing acceptance tests, see the main Terraform contributing guide.
This provider uses Go modules.
To add a new dependency to your Terraform provider:
go get github.com/author/dependency
go mod tidy
Then commit the changes to go.mod
and go.sum
.
The original version of the Aiven Terraform provider was written and maintained by Jelmer Snoeck.