#gcp (2024-03)
Google Cloud Platform
2024-03-01
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
Question. In atmos.yaml we are using “auto_generate_backend_file: true” and seeing in S3 atmos creating a folder for component then a sub-folder for stack, which it them places the terraform.tf into. When we run the same layout of components/stacks/config against GCP GCS we are seeing only a state file be created, no folders, example core-usc1-auto.tfstate which it is renaming the terraform.tf to which is the name of the stage. Has anyone seen this behaviour or can advise? Thanks
Google Cloud Platform lets you build, deploy, and scale applications, websites, and services on the same infrastructure as Google.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
did you correctly configure GCP backend in Atmos manifests? something like this:
terraform:
# Backend
backend_type: gcs
backend:
gcs:
bucket: "xxxxxxx-bucket-tfstate"
prefix: "terraform/tfstate"
Google Cloud Platform lets you build, deploy, and scale applications, websites, and services on the same infrastructure as Google.
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
In a _defaults.yaml in a parent stack folder that in imported we have:
terraform:
backend_type: gcs
backend:
gcs:
bucket: poc-tfstate-bucket
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and seeing in S3 atmos creating a folder for component then a sub-folder for stack,
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
can you give more details on this? (I don’t understand “atmos creating a folder for component then a sub-folder for stack” - the folders for components and stacks must already exist in your repo)
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
In AWS the bucket has these folders, that are components.
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
Followed by these stacks folders
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok, so you are saying that the S3 backend creates those folders in the S3 bucket, but you are not seeing the GCP backend creating those folders in the GCP bucket?
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
yes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it depends on TF backend and workspaces. In AWS S3 backend, for example, the workspace_key_prefix
(which you can specify in Atmos config for each component; if not specified, then Atmos component name is used) is the main folder name. The TF workspaces for diff stacks are subfolders. That’s how the S3 backend in TF works
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(I’m not sure if GCP backend works the same way, or it just creates a flat folder structure - you need to confirm that in terrform docs for GCP)
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
Thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to confirm if GCP backend has a similar concept like workspace_key_prefix
in the AWS S3 backend (which creates those top-level folders in the S3 state bucket)
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
Thank You, will look into that feature.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/bae01/bae01c7556d626fec045b1f90dc9c0187438d13b" alt="attachment image"
Terraform can store the state remotely, making it easier to version and work with in a team.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I think it’s the prefix
(which is the same as orkspace_key_prefix
in the S3 backend)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can configure prefix
for each component in Atmos manifests
components:
terraform:
<my-component>:
backend:
gcp:
prefix: <my-component>
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Atmos does not generate prefix
for GCP automatically, it only does it for S3 backend workspace_key_prefix
(we will take a look at this to add it to Atmos to generate prefix
automatically using Atmos components names if prefix
is not configured for a component)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for now, try the above config on your components, it should generate the folders inside the state bucket (Named states for workspaces are stored in an object called <prefix>/<name>.tfstate
.)
data:image/s3,"s3://crabby-images/1f612/1f61254879945ee8fc5ee4f8950b3b908371c406" alt="Christopher McGill avatar"
Thanks, that is working.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
super
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thank you for testing and pointing it out - we’ll add the auto-generation of prefix
for GCP backend to Atmos (similar to what it does for workspace_key_prefix
for S3 backend)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
auto-generation of prefix
for gcs
backend was added to Atmos 1.65.0
2024-03-23
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
Hello Team, Im planning to start a GCP setup via atmos. Can some one provide me with basic structure ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This one has some examples for GCP
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
An opinionated, multi-cloud, multi-region, best-practice accelerator for Terraform.
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
thanks @Erik Osterman (Cloud Posse)
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
I want to target multiple services in different projects, example : cloudfunction should go to project1 and all cloudrun should be project2 and storage in project3. So how can i design such a way each stack can go to different project
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That makes sense. Projects might be like accounts in AWS. So you have project level isolation.
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
yes !
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
data:image/s3,"s3://crabby-images/a6152/a615209681bce0d50173f73aaf3a8f7dc0b0c195" alt="attachment image"
In this article, you will not just learn about terraform providers but will also learn how to deploy cloud resources across multiple…
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
so i might have different service account for each project
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Monish Devendran please review these docs (they are for AWS, but you can update them for GCP)
https://atmos.tools/design-patterns/organizational-structure-configuration
Organizational Structure Configuration Atmos Design Pattern
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Use the atmos.yaml
configuration file to control the behavior of the atmos
CLI.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the pattern is, you define your stack config per Org, project, account, etc. (configure the context variables in each). Then define or import the Atmos components into each top-level stack.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can define defaults for each component in catalog
, then import the defaults into the stacks, and override the component config per stack if needed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(you can DM me your setup, I’ll review)
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
@Andriy Knysh (Cloud Posse), Thanks . setup and will send
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
extended from atmos to leverage orchestration in terraform
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
very basic setup, im trying to read above links and trying to see. also can you send me a link to configure terraform cloud
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’ll review your repo, thanks for sharing
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
configure terraform cloud
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/bae01/bae01c7556d626fec045b1f90dc9c0187438d13b" alt="attachment image"
Collaborate on version-controlled configuration using Terraform Cloud. Follow this track to build, change, and destroy infrastructure using remote runs and state.
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
yes , my statefiles i want to run in tf cloud
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Or more specifically use terraform cloud strict as a state backend? Or also use the deployment capabilities as well of terraform cloud
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Monish Devendran I’ve sent you a zip file with the infra configuration for GCP with a few stages (dev, prod, staging) and a few GCP projects with multiple Atmos components in each (specific component type like Cloud Functions and GCS buckets per GCP project). We can sync anytime to review it
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
Hi @Erik Osterman (Cloud Posse), So my use case is to use terraform cloud to run terraform apply and store them in tf cloud
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
In that case you will need to commit the varfiles and configure terraform cloud to use the appropriate varfile with each workspace
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
To do that see this comment, https://github.com/hashicorp/terraform/issues/15966#issuecomment-1868823558
I was able to do this with Terraform Cloud by adding an environment variable to the workspace:
Key: TF_CLI_ARGS
Value: -var-file "dev.tfvars"
Now when I run terraform apply
it turns into terraform apply -var-file dev.tfvars
. It will do this for all terraform commands. (See here: https://developer.hashicorp.com/terraform/cli/config/environment-variables#tf_cli_args-and-tf_cli_args_name)
It would be better if we could apply this in the code itself though.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Heads up, @RB I saw you commented on this thread and this appears to be solution.
2024-03-24
2024-03-28
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
Can someone help me,
Im trying to pass a secret which is stored in akeyless,
data "akeyless_secret" "secret" {
path = "/GCP/Secrets/cf-triggers/tf-cf-triggers"
}
provider "google" {
project = "cf-triggers"
credentials = data.akeyless_secret.secret
}
resource "google_pubsub_topic" "example" {
name = "akeyless_topic"
message_retention_duration = "86600s"
}
❯ terraform apply
data.akeyless_secret.secret: Reading...
data.akeyless_secret.secret: Read complete after 1s [id=/GCP/Secrets/cf-triggers/tf-cf-triggers]
Planning failed. Terraform encountered an error while generating this plan.
╷
│ Error: Incorrect attribute value type
│
│ on main.tf line 38, in provider "google":
│ 38: credentials = data.akeyless_secret.secret
│ ├────────────────
│ │ data.akeyless_secret.secret is object with 4 attributes
│
│ Inappropriate value for attribute "credentials": string required.
data:image/s3,"s3://crabby-images/3e08b/3e08bacf5ec502448b3444fca7a7b7215d0907e8" alt="Monish Devendran avatar"
Has anyone faced this issue, not able to pass secret from akeyless