#gcp (2023-02)
Google Cloud Platform
2023-02-27
2023-02-28
data:image/s3,"s3://crabby-images/3add0/3add0cd38f0e3aa18e0622f5ab59d893bf2dfa72" alt="DaniC (he/him) avatar"
Hi folks, anyone aware of a similar TF module like https://github.com/cloudposse/terraform-null-label but for GCP ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the context variables namespace
, environment
, tenant
, stage
- you can use all of them or just those that you need
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
namespace
is your Org
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
environment
is a region
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
tenant
is a subdivision in your Org (OU in AWS)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
stage
is the account
data:image/s3,"s3://crabby-images/3add0/3add0cd38f0e3aa18e0622f5ab59d893bf2dfa72" alt="DaniC (he/him) avatar"
thx a bunch @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/3add0/3add0cd38f0e3aa18e0622f5ab59d893bf2dfa72" alt="DaniC (he/him) avatar"
(was surprised to see that there are no other modules like this embedded in any of the supported google tf modules)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the module is used to uniquely and consistently naming cloud resources. If you use all the context vars, the resulting resource name/Id would look like {namespace}-{tenant}-{environment}-{stage}-{name}
, for example for an AWS resource it could be cp-plat-ue1-prod-vpc-logs-bucket
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
same thing could be used for GCP
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
by using that, you can tell right away the stack that the resource belongs to by looking at the resource name/ID
data:image/s3,"s3://crabby-images/3add0/3add0cd38f0e3aa18e0622f5ab59d893bf2dfa72" alt="DaniC (he/him) avatar"
indeed. The whole reason i want to use it is to support multiple deployments within same GCP project like:
• ephemeral/ sandbox envs
• uat
• etc