Resource Packs

Cloud

Example

Flavor

Feature

Postgres

Example: postgres resource using a Kubernetes StatefulSet

This example configures a postgres Resource Definition using Kubernetes StatefulSet.

Requirements

Name Version
terraform >= 1.3.0
humanitec ~> 1.0

Providers

Name Version
humanitec ~> 1.0

Modules

Name Source Version
postgres_basic ../../humanitec-resource-defs/postgres/basic n/a

Resources

Name Type
humanitec_resource_definition_criteria.postgres_basic resource

Inputs

Name Description Type Default Required
prefix Prefix of the created resources string "hum-rp-postgres-ex-" no

Deploy and use this example

To deploy this resource definition, run these commands below:

git clone https://github.com/humanitec-architecture/resource-packs-in-cluster

cd examples/postgres/

humctl login
humctl config set org YOUR-ORG

terraform init
terraform plan
terraform apply

The created Resource Definition can be used in your Score file like illustrated below:

apiVersion: score.dev/v1b1
metadata:
  name: my-workload
containers:
  my-container:
    image: nginx:latest # this container image is just used as an example, it's not talking to postgres.
    variables:
      POSTGRES_CONNECTION_STRING: "postgresql://${resources.my-postgres.username}${resources.my-postgres.password}@${resources.my-postgres.host}:${resources.my-postgres.port}/${resources.my-postgres.name}"
resources:
  my-postgres:
    type: postgres

This Score file when deployed to Humanitec will provision the postgres database and inject the outputs in the associated environment variable.

Here is how to deploy this Score file, for example to the postgres-example Application and development Environment:

humctl create app postgres-example

humctl score deploy \
    -f score.yaml \
    --app postgres-example \
    --env development

main.tf (view on GitHub) :

module "postgres_basic" {
  source = "github.com/humanitec-architecture/resource-packs-in-cluster?ref=v2024-09-18//humanitec-resource-defs/postgres/basic"

  prefix = var.prefix
}

resource "humanitec_resource_definition_criteria" "postgres_basic" {
  resource_definition_id = module.postgres_basic.id
  class                  = "default"
  force_delete           = true
}


providers.tf (view on GitHub) :

terraform {
  required_providers {
    humanitec = {
      source  = "humanitec/humanitec"
      version = "~> 1.0"
    }
  }
  required_version = ">= 1.3.0"
}


provider "humanitec" {}


terraform.tfvars.example (view on GitHub) :


# Prefix of the created resources
prefix = "hum-rp-postgres-ex-"

variables.tf (view on GitHub) :

variable "prefix" {
  description = "Prefix of the created resources"
  type        = string
  default     = "hum-rp-postgres-ex-"
}

Top