#terraform (2022-09)
Discussions related to Terraform or Terraform Modules
Archive: https://archive.sweetops.com/terraform/
2022-09-01
data:image/s3,"s3://crabby-images/7a050/7a0502428e428e7c6930fd927f0e6d06ea418c0b" alt="Nitin avatar"
what
• Remove join splat on module.security_group_arn
why
• Fix conflict with using custom security group in associated_security_group_ids
and argument create_security_group
is false
references
• N/A
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
please post in #pr-reviews
what
• Remove join splat on module.security_group_arn
why
• Fix conflict with using custom security group in associated_security_group_ids
and argument create_security_group
is false
references
• N/A
data:image/s3,"s3://crabby-images/791cb/791cb20cce9e34637e83b380f94ba2addc1e9dda" alt="sripe avatar"
Hi, I have a map object as below. I was able to go one level down and was able to get the entire “dev” value . how do i get only node_group_name value ?
managed_node_groups = {
"dev" = {
eks = {
node_group_name = "node-group-name1"
instance_types = ["m5.large"]
update_config = [{
max_unavailable_percentage = 30
}]
}
mng_custom_ami = {
node_group_name = "mng_custom_ami"
custom_ami_id = "ami-0e28cf2562b7b3c9d"
capacity_type = "ON_DEMAND"
}
}
"qe"= {
eks = {
node_group_name = "node-group-name2"
instance_types = ["m5.large"]
}
mng_custom_ami = {
node_group_name = "mng_custom_ami"
custom_ami_id = "ami-0e28cf2562b7b3c9d"
capacity_type = "ON_DEMAND"
block_device_mappings = [
{
device_name = "/dev/xvda"
volume_type = "gp3"
volume_size = 150
}
]
}
}
}
variable env {}
mng = var.managed_node_groups[var.env]
data:image/s3,"s3://crabby-images/841d8/841d8f1ee11a8cded4e036c005f1c6950035c636" alt="Max avatar"
var.managed_node_groups[*].eks["node_group_name"]
data:image/s3,"s3://crabby-images/841d8/841d8f1ee11a8cded4e036c005f1c6950035c636" alt="Max avatar"
data:image/s3,"s3://crabby-images/1040f/1040f3abeb728103f8e4c0b9b7945ae05546663d" alt="attachment image"
Reference values in configurations, including resources, input variables, local and block-local values, module outputs, data sources, and workspace data.
data:image/s3,"s3://crabby-images/791cb/791cb20cce9e34637e83b380f94ba2addc1e9dda" alt="sripe avatar"
thank you, how to get the node_group_name of just the first element for each environment, if i dont want to hardcode .eks below
var.managed_node_groups[*].eks["node_group_name"]
2022-09-02
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
could anyone suggest, what will be the perfect auto-scaling during the high traffic of the ecs fargate, and also send me the github link for my reference, thanks in advance.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
7 is the perfect scale
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
@Alex Jurkiewicz would you recommand any github links for creating perfect autoscaling tf?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
this slack is run by Cloudposse, who publish many Terraform modules. Check out their repos here: https://github.com/cloudposse/
DevOps Accelerator for Startups Hire Us! https://slack.cloudposse.com/
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
start with these resources, do few tests,
resource "aws_appautoscaling_target" "ecs_target" {
max_capacity = 4
min_capacity = 1
resource_id = "service/${aws_ecs_cluster.example.name}/${aws_ecs_service.example.name}"
scalable_dimension = "ecs:service:DesiredCount"
service_namespace = "ecs"
}
resource "aws_appautoscaling_scheduled_action" "dynamodb" {
name = "dynamodb"
service_namespace = aws_appautoscaling_target.ecs_target.service_namespace
resource_id = aws_appautoscaling_target.ecs_target.resource_id
scalable_dimension = aws_appautoscaling_target.ecs_target.scalable_dimension
schedule = "at(2006-01-02T15:04:05)"
scalable_target_action {
min_capacity = 1
max_capacity = 200
}
}
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
in your case use CloudPosse’s modules as target
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
thank you
2022-09-03
2022-09-04
data:image/s3,"s3://crabby-images/b4d58/b4d5873c7ad577cf78d4cd0686a7458cbba5957e" alt="Amit Karpe avatar"
What is best practise to install packages and configure few settings in ec2 instance? Do you prefer provisioner with “remote-exec”? or Ansible or packer? I need to run an applications in four ec2 instance with pre-configuration. I have shell script ready but wanted to know better approach.
data:image/s3,"s3://crabby-images/f423c/f423c8e850268e533a4e86e173d6f4a9a3b27039" alt="managedkaos avatar"
I would suggest keeping the server configuration out of terraform and use something like Ansible instead.
For my projects that involve a server or two, an application installation, and a bit of configuration, I’ve found the following to be the best approach:
- Keep the application code in one repo
- Keep the TR infra code in another repo
- Keep the server and application config in another repo and use ansible to: a. Install user/service accounts b. Configure and update the server c. deploy the application
data:image/s3,"s3://crabby-images/f423c/f423c8e850268e533a4e86e173d6f4a9a3b27039" alt="managedkaos avatar"
Having ansible and config in its own repo makes it easy to manage and deploy environments in a way that doesn’t require re-running TF or rebuilding the application. Also, its much easier to track configuration changes vs app or infra changes. Yes, in some cases a big change requires coordination across all three repos. but is most cases (daily operation), the only thing that changes is the config repo its much easier to track and apply changes there.
data:image/s3,"s3://crabby-images/b4d58/b4d5873c7ad577cf78d4cd0686a7458cbba5957e" alt="Amit Karpe avatar"
Thank you. I will revise my ansible knowledge I was planning to invest time to learn packer (to build machine images ) and deploy/provision then using Terraform.
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
Hi everyone, I supposed to create ecs on multi region using tf, now ecs running on us-east-1, could anyone help me to solve this problem. Thanks in advance
2022-09-05
data:image/s3,"s3://crabby-images/2c542/2c5428cb5f8a5bfd303be4b4c99320e0efcb7b39" alt="James avatar"
Hey guys - I have creation of ECR in my TF. How do you flag the ECR part to avoid destroying it during executing terraform destroy
?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
You can delete the resources manually from the state file before running terraform destroy
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
See terraform state rm
data:image/s3,"s3://crabby-images/2c542/2c5428cb5f8a5bfd303be4b4c99320e0efcb7b39" alt="James avatar"
Awesome! Thanks @Alex Jurkiewicz!
2022-09-06
data:image/s3,"s3://crabby-images/be0e5/be0e5f643e1eb22f781fd36f0a4c59f8de035f07" alt="Manjunath shetty avatar"
I have created multiple ec2 instance using count . In that one ec2 instance deleted using -target option or manually . In the subsequent deployment I want terraform to skip the deployment of manual deleted instance. How to achieve this?
data:image/s3,"s3://crabby-images/be0e5/be0e5f643e1eb22f781fd36f0a4c59f8de035f07" alt="Manjunath shetty avatar"
resource "aws_instance" "web" {
count = 4 # create four similar EC2 instances
ami = "ami-00785f4835c6acf64"
instance_type = "t2.micro"
tags = {
Name = "Server ${count.index}"
}
lifecycle {
ignore_changes = [
aws_instance.web[1]
]
}
}
data:image/s3,"s3://crabby-images/be0e5/be0e5f643e1eb22f781fd36f0a4c59f8de035f07" alt="Manjunath shetty avatar"
i try to implement using lifecylce ignore change but getting error This object has no argument, nested block, or exported attribute named “aws_instance”.
data:image/s3,"s3://crabby-images/be0e5/be0e5f643e1eb22f781fd36f0a4c59f8de035f07" alt="Manjunath shetty avatar"
Any pointers on this?
data:image/s3,"s3://crabby-images/615cf/615cf719bd5919b05de675cf9943cac22ddc67b3" alt="Pierre-Yves avatar"
I’m not sure that the ignore_changes is compatible with what you want to achieve. you can ignore changes for a specific attribute or block of a ressource, but [I THINK] not for an entire resource.
It’s my own opinion, I let other answer if it is possible
data:image/s3,"s3://crabby-images/be0e5/be0e5f643e1eb22f781fd36f0a4c59f8de035f07" alt="Manjunath shetty avatar"
Thanks @Pierre-Yves. If we reduce the count then it will be impacted across all the subnets. Is there any other option without reducing the count?
data:image/s3,"s3://crabby-images/615cf/615cf719bd5919b05de675cf9943cac22ddc67b3" alt="Pierre-Yves avatar"
What do you mean by “reduce the count”.
For my part, i was not telling you to change your count ^^. I was just saying that I think you can’t use the ignore_changes meta-argument for your need
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
data:image/s3,"s3://crabby-images/1040f/1040f3abeb728103f8e4c0b9b7945ae05546663d" alt="attachment image"
How to make backward-compatible changes to modules already in use.
data:image/s3,"s3://crabby-images/be0e5/be0e5f643e1eb22f781fd36f0a4c59f8de035f07" alt="Manjunath shetty avatar"
2022-09-07
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
can anyone help me to ..assign ecs fargate public ip to target group, now private ip is assigned on target group.
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.2.9 1.2.9 (September 07, 2022) ENHANCEMENTS: terraform init: add link to documentation when a checksum is missing from the lock file. (#31726)
Original PR: #31408 Backport PR: #31480 For some reason the backport process only picked up the first two commits from the original PR. This PR manually copies over the changes missed by the backpo…
2022-09-08
data:image/s3,"s3://crabby-images/2c542/2c5428cb5f8a5bfd303be4b4c99320e0efcb7b39" alt="James avatar"
Hey guys,
Running an initial terraform apply
has been failed due to expired aws credential. I updated the creds and rerunning apply, it’s failed once again due to the resources being existed already resulted from the initial applied earlier.
How do you approach with this kind of case?
data:image/s3,"s3://crabby-images/e7035/e703511b9a478652c7dd4fecc06408ebdff0c841" alt="Ralf Pieper avatar"
I think a screen share might let me understand. If you cann’t rerun something bigger is wrong like the way the code is structured.
data:image/s3,"s3://crabby-images/e7035/e703511b9a478652c7dd4fecc06408ebdff0c841" alt="Ralf Pieper avatar"
I don’t know what the resource is, the simple solution would be to delete it, if that is possible? Then it will be rebuilt.
data:image/s3,"s3://crabby-images/e7035/e703511b9a478652c7dd4fecc06408ebdff0c841" alt="Ralf Pieper avatar"
I have seen it sometimes where a plan says resource will get remade, even though I think it isn’t needed.
data:image/s3,"s3://crabby-images/ee773/ee77365d793dc5059e7c54cd2456664abf4fee52" alt="Chris Dobbyn avatar"
Because your session expired while the resource was being created and presumably your state lives in s3 or something similar (dependent on your session) the state has gone out of wack from the reality.
In order to remediate you will need to perform terraform import
operations on the resources that were created and then not recorded into state.
data:image/s3,"s3://crabby-images/fa6de/fa6de14bd39dca785f058a9f4ea1c99b501d8a83" alt="Jonathan Forget avatar"
I think when a apply failed due to expired credentials, it should save a tfstate locally, pushing this tfstate to your backend should fix the issue.
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
I discovered recently while I was looking at using HCL Go libraries to do our own config processing, that TF 1.3 will have some pretty awesome improvements to config defaults. And I saw in this channel a syndicated post about it just now, but it might have gotten missed, so I’m writing this.
The improvement actually goes way beyond providing the optional value in the optional()
function call. That improvement alone is great, because it allows for a much more natural way to declare default objects and easier to grok the structure (instead of using a separate default
attribute in variable
. or defaults()
function).
But HC also fixed a major issue with defaults merge in 1.2 (as was available in both deafult
attrib and defaults()
function): it will create default nested objects to full depth based on the spec. Which it does not do in the experimental support available in 1.2, thus rendering the defaults()
function almost useless (IMO).
There’s really only 2 use cases that these 1.3 improvements do not solve for me, but I can live without them (whereas the issues that 1.3 fixes were deal breakers for us and we were going to roll our own using hclwrite lib).
I’ll be moving our current in-house config system to use the new capabilities of 1.3 over the next few weeks (depends on client priorities, might take longer), very excited to see how far I can get.
v1.3.0-beta1 1.3.0 (Unreleased) NEW FEATURES:
Optional attributes for object type constraints: When declaring an input variable whose type constraint includes an object type, you can now declare individual attributes as optional, and specify a default value to use if the caller doesn’t set it. For example: variable “with_optional_attribute” { type = object({ a = string # a required attribute b = optional(string) # an optional attribute c = optional(number, 127) # an…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
does the defaults()
function still even exist in 1.3? i thought it was part of the optional experiment, and the experiment was removed in 1.3…
v1.3.0-beta1 1.3.0 (Unreleased) NEW FEATURES:
Optional attributes for object type constraints: When declaring an input variable whose type constraint includes an object type, you can now declare individual attributes as optional, and specify a default value to use if the caller doesn’t set it. For example: variable “with_optional_attribute” { type = object({ a = string # a required attribute b = optional(string) # an optional attribute c = optional(number, 127) # an…
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
yes defaults()
has been removed entirely (the experiment_optional option has been removed altogether). Only optional()
is left (and it’s a lot better than previous, as I explained).
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
yep, tracking. long thread on its progress here, https://discuss.hashicorp.com/t/request-for-feedback-optional-object-type-attributes-with-defaults-in-v1-3-alpha/40550
Hi all , I’m the Product Manager for Terraform Core, and we’re excited to share our v1.3 alpha , which includes the ability to mark object type attributes as optional, as well as set default values (draft documentation here). With the delivery of this much requested language feature, we will conclude the existing experiment with an improved design. Below you can find some background information about this language feature, or you can read on to see how to participate in the alpha and pro…
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
yes that’s how I found out about it
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
Actually, found out about it in https://github.com/hashicorp/terraform/issues/28344 which also has interesting background about current (ie 1.2 experiment) limitations and links to that one you posted
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
it should be great. But I wouldn’t be too quick on using Terraform betas. Some of them have done things like zero state in the past
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
I think a 1.x beta (or perhaps even x.0) had a bug where it would plan to remove all resources in certain conditions?
data:image/s3,"s3://crabby-images/791cb/791cb20cce9e34637e83b380f94ba2addc1e9dda" alt="sripe avatar"
hey guys, how are you managing user creation in rds, any best practices ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
clusters?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
aurora?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
global?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mysql?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we need more details
data:image/s3,"s3://crabby-images/791cb/791cb20cce9e34637e83b380f94ba2addc1e9dda" alt="sripe avatar"
aurora/rds mysql clusters. i tried to search for a resource in terraform to create generic users other than the master one , but couldnt find any
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
there is a mysql user provider you can use
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/dfed7/dfed7bb76ce83f846564d41c35c2d88fde33f841" alt="Warren Parad avatar"
Not? Use IAM connected RDS user integration
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you can use that too, yes I forgot about that
2022-09-09
data:image/s3,"s3://crabby-images/8388f/8388ffb5d3d4593d65f49ba2c3655b95443293e1" alt="Jonas Steinberg avatar"
Module development and best practices Looking for experience and opinions
data:image/s3,"s3://crabby-images/8388f/8388ffb5d3d4593d65f49ba2c3655b95443293e1" alt="Jonas Steinberg avatar"
Tough not to have some of these overlap with just vanilla tf practices, but doing this for my team and thought I would post here for other people’s input as well
• modules do not reinvent the wheel e.g. if there is an aws module, a cloudposse module or similar these are used instead of home-rolling
• modules have documentation and examples
• modules have terratests
• module code avoids code smells like ternaries, excessive remote state lookups
• modules avoid using shell providers as much as possible
• modes avoid reading or writing files at local or remote locations for the purposes of getting or creating effectively hard-coded information to then be used in later logic
• modules are versioned and a versions file is used to pin modules
• expose important outputs
• limited use of custom scripts
• modules follow a universally agreed-upon naming convention
• modules are integrated with environment specific code and do not rely on lookups, etc to figure out what environment specific values to get
• modules are not too specific, e.g. a databricks-s3-encrypted-with-kms-and-object-replication
module should be instead databricks-component-a
, databricks-component-b
, …, kms-cm-key
, s3
modules and all of these should be used from the tf registry via cloudposse, aws, or similar well-known publishers
• the root module should only call modules
• aws account numbers should be looked up, not hardcoded in tf files
data:image/s3,"s3://crabby-images/615cf/615cf719bd5919b05de675cf9943cac22ddc67b3" alt="Pierre-Yves avatar"
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i would add one, avoid using depends_on if at all possible, and make a special effort to avoid module-level depends_on (as opposed to resource-level depends_on). always prefer passing attributes instead, which terraform will use to construct the graph
data:image/s3,"s3://crabby-images/8388f/8388ffb5d3d4593d65f49ba2c3655b95443293e1" alt="Jonas Steinberg avatar"
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
“the root module should only call modules”? What is a “root module”?
“A versions file is used to pin modules” Do you mean pinning providers?
I agree with most of the rest, but the list feels a bit “write clean code where possible, we won’t explain why these dot points lead to clean code or why clean code is good tho”
data:image/s3,"s3://crabby-images/8388f/8388ffb5d3d4593d65f49ba2c3655b95443293e1" alt="Jonas Steinberg avatar"
@Alex Jurkiewicz https://www.terraform.io/language/modules#the-root-module
data:image/s3,"s3://crabby-images/1040f/1040f3abeb728103f8e4c0b9b7945ae05546663d" alt="attachment image"
Modules are containers for multiple resources that are used together in a configuration. Find resources for using, developing, and publishing modules.
data:image/s3,"s3://crabby-images/8388f/8388ffb5d3d4593d65f49ba2c3655b95443293e1" alt="Jonas Steinberg avatar"
I meant to say modules should be pinned in source references
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i consider a “root module” to be one that owns the backend config, state, the lock file, provider block configurations, and the config inputs
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
basically a “module” that you have designed explicitly to support directly running the init/plan/apply/destroy workflow for one or more configurations
data:image/s3,"s3://crabby-images/bc4dc/bc4dcc6e4c513cfaf9fe8542f27a51da016e4946" alt="Simpson Say avatar"
Hi team — hoping to get some eyes on this when someone has the time: https://github.com/cloudposse/terraform-datadog-platform/pull/71
what
• lookup function did not pull the correct value required for thresholds, and instead went to the default.
• This resulted in an error when creating an SLO of type monitor
when using more then one threshold.
why
• We are creating all of our metrics, monitors, SLOs, etc with IaC, using cloud posse’s modules (thanks!)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
please post to #pr-reviews
what
• lookup function did not pull the correct value required for thresholds, and instead went to the default.
• This resulted in an error when creating an SLO of type monitor
when using more then one threshold.
why
• We are creating all of our metrics, monitors, SLOs, etc with IaC, using cloud posse’s modules (thanks!)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Does the free edition of terraform cloud still require each workspace hardcode AWS credentials? Or can you setup an IAM role that it can assume?
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
In the free version you can configure the workspace to use API mode which will then make TF cloud just a state holder. In API mode, you define the workflow and provide the hardware to run the plans. E.g. you could run it in GitHub actions with GitHub runners. This then allows you to decide how you want to provide credentials. A role on the runners? GitHub secrets configured in the pipeline that then assumes a role? Basically you have full control.
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
You’ll also need to set local execution mode.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Fizz just confirming my understanding.
in that mode though, there are zero audit trails, no confirmations, and nothing represented in TFC, right? It’s only serving as the state backend (a glorified s3 bucket). To your point, you could then run terraform in conventional CI/CD, but TFC is providing no other benefit than state management.
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
Yes. In the paid version, you can have runners on your own infra managed by tf cloud. There you can attach a role to your runner (assuming you are on AWS)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I just find it odd that they don’t support the more native integration model where you provision an IAM role that trusts their principle and allow them to assume the role. This is how free/entry-level plans of Datadog and Spacelift work. Presumably others as well.
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
Yep. Cross account role that can be assumed by a user, or role, in their account would be a nice feature.
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
It might be a deliberate omission though. I’ve heard on the paid plan they charge $50 per apply. So it seems like they really want to encourage you to run on your own hardware.
data:image/s3,"s3://crabby-images/97527/97527661c57a4d96624c2449062198f6749a97df" alt="IK avatar"
I’ve just set this up using OIDC providers in each account (deployed via stacksets).. then it’s just a matter of exposing the TFC_WORKLOAD_IDENTITY_TOKEN environment variable (i use the Epp0/environment provider) and bang.. multi-account TFC deployments using JWT
2022-09-11
2022-09-12
data:image/s3,"s3://crabby-images/01984/01984b242999732fa0ead53279a5919dba45f84e" alt="muhaha avatar"
Hey, are You using Checkov/TFsec/Kicks in CI ( Github Actions for example ) ? I just wanted to ask, I just discovered https://github.com/security-alert/security-alert/tree/master/packages/sarif-to-comment/, which can effectively convert SARIF to GH comment… But its not working correctly, because all these tools are predownloading modules and analyses them with given input on the filesystem. So It can generate comments, but it will generate diff URLs based on local path, instead of just pointing to the correct “upstream” module called from main.tf. Ideas?
data:image/s3,"s3://crabby-images/8c500/8c5001b395db17306370340122ebee19eea8d4d3" alt="Shlomo Daari avatar"
Does anyone know why I’m getting this error? An argument named "iam_role_additional_policies" is not expected here.
In the Terraform site, it shows that this should be under the module eks section.
data:image/s3,"s3://crabby-images/e7035/e703511b9a478652c7dd4fecc06408ebdff0c841" alt="Ralf Pieper avatar"
I’m happy to take a look, I don’t think I have enough context to do anything but a google search.
data:image/s3,"s3://crabby-images/8c500/8c5001b395db17306370340122ebee19eea8d4d3" alt="Shlomo Daari avatar"
I tried to configure the following:
create_iam_role = true
iam_role_name = "eks-manage-nodegroup-shlomo-tf"
iam_role_use_name_prefix = false
iam_role_description = "Self managed node group role"
iam_role_tags = {
Purpose = "Protector of the kubelet"
}
iam_role_additional_policies = [
"arn:aws:iam::aws:policy/AmazonEC2ContainerRegistryReadOnly",
"arn:aws:iam::810711266228:policy/SecretsManager-CurrentValueROAccess",
"arn:aws:iam::810711266228:policy/SecretsManager-CurrentValueROAccess"
]
https://registry.terraform.io/modules/terraform-aws-modules/eks/aws/latest?tab=inputs
data:image/s3,"s3://crabby-images/8c500/8c5001b395db17306370340122ebee19eea8d4d3" alt="Shlomo Daari avatar"
Thank you for the help
2022-09-13
data:image/s3,"s3://crabby-images/b7fba/b7fba7dbee9c5f3fdb182918ac1454f3e9f8d688" alt="Tommy avatar"
is it somehow possible to test the github action pipelines of the modules locally or within the fork? I have some troubles to pass all pipeline steps
data:image/s3,"s3://crabby-images/12e5a/12e5ac5eb1dc585885ce606a1b42d4ff4dc88d5e" alt="Andrey Taranik avatar"
@Tommy yes, answer is act
data:image/s3,"s3://crabby-images/78701/78701e63b3ea513290fca8a066c55cba3d3cb90b" alt="this"
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
act
is awesome! Though, in most cases, for me it ended up being slower than just pushing and letting github handle it. I store logs as artifacts so I can troubleshoot better
data:image/s3,"s3://crabby-images/b7fba/b7fba7dbee9c5f3fdb182918ac1454f3e9f8d688" alt="Tommy avatar"
thank you, I will take a look!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and watch out, you can do things in ACT that do not work in the actual github actions runners
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I know some members on the team of tried it a couple times and given up because they didn’t get any further. They’d get it working in ACT, then it wouldn’t work in the runners. Vise versa.
2022-09-14
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.3.0-rc1 1.3.0 (Unreleased) NEW FEATURES:
Optional attributes for object type constraints: When declaring an input variable whose type constraint includes an object type, you can now declare individual attributes as optional, and specify a default value to use if the caller doesn’t set it. For example: variable “with_optional_attribute” { type = object({ a = string # a required attribute b = optional(string) # an optional attribute c = optional(number, 127) # an…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/e4774/e4774f7103a5b68a7bba9046a50791e5b77de7b4" alt="jimp avatar"
Hypothetical reasons to arrest an actual Terraform founder in this thread please
data:image/s3,"s3://crabby-images/e4774/e4774f7103a5b68a7bba9046a50791e5b77de7b4" alt="jimp avatar"
For example, South Korea court reportedly issues arrest warrant for Terraform founder for AWS Provider v3 rollout.
data:image/s3,"s3://crabby-images/13ba6/13ba6046042d92f6e2153ef5d99bf1a792713776" alt="Tyrone Meijn avatar"
South Korea court reportedly issues arrest warrant for Terraform founder for charges that cannot be determined until apply
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
South Korea court reportedly issues an arrest warrant for Terraform founder for abusing local exec’s to manipulate the stock price.
data:image/s3,"s3://crabby-images/279d9/279d967e82dbc5220558ad291666976a271ee383" alt="Mallikarjuna M avatar"
Hi Team, can some one help me with creating IAM user in terraform by passing variable from values.yml file
2022-09-15
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
Has anyone tried using any of the existing EKS related TF modules to deploy a Windows EKS node group for a cluster?
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
@andylamp @Jeremy G (Cloud Posse) Do either of you know if the cloudposse/eks-workers/aws
module should be able to accomplish this and set the self-managed node group similar to the Linux managed node group?
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
@Jeremy (UnderGrid Network Services) I have never worked with a Windows EKS node group, and do not know the specifics, but I would expect cloudposse/eks-workers/aws
module should be able to launch Windows nodes by selecting the appropriate AMI via eks_worker_ami_name_filter
and eks_worker_ami_name_regex
or image_id
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
I thought as much. The hangup I’ve found with the eks-workers module is that it doesn’t allow me to override the user data which is obviously going to be different for windows than linux
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
With eka-node-groups can provide user data base64 encoded and it over rides the default I believe
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
Specifying userdata is not a requirement to launch a node; EKS supplies appropriate defaults.
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
Not in the case of Windows eks nodes
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
I don’t see anything in the AWS documentation about setting userdata. Please educate me.
This topic describes how to launch Auto Scaling groups of Windows nodes that register with your Amazon EKS cluster.
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
if you read through you find the cloudformation template they have (https://s3.us-west-2.amazonaws.com/amazon-eks/cloudformation/2020-10-29/amazon-eks-windows-nodegroup.yaml) and it has a user data block that it includes in the launch template that the ASG calls
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
even the eks-node-group
module has a user data template for Linux managed node groups but the module has the userdata_override_base64
variable if you want to override the default. eks-workers
doesn’t have any similar mechanism and the userdata.tpl
is Linux specific
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
OK, I admit that I’m not completely following because TBH I believe you and don’t want to spend the time to learn it right now. Short story is that if you want to duplicate the relevant inputs from eks-workers
in eks-node-group
in a PR I will approve it.
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
okay… I’ll work on a PR and test it… I know this is likely a bit of a niche situation as I have our dev team asking to include a Windows EKS node group to our cluster so they can work on moving some of the application(s) that runs on Windows into EKS and off EC2
data:image/s3,"s3://crabby-images/f32e8/f32e85f027666416b654b0749258dcbce33cf974" alt="Jeremy G (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/b3f45/b3f45326a2e9de126f922d0fafce07263fd82059" alt="johnny avatar"
Hey @Jeremy (UnderGrid Network Services) do you have any progress or tips on this?
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
@johnny I have been a bit sidetracked lately wearing my firefighter hat so haven’t made the progress I wanted on it. The dev I was working with managed to get the Windows node up and running via click-ops after I’d stood up the Linux node group via TF but I haven’t gotten his steps into my TF yet.
data:image/s3,"s3://crabby-images/b3f45/b3f45326a2e9de126f922d0fafce07263fd82059" alt="johnny avatar"
@Jeremy (UnderGrid Network Services) That’s fair. Do you happen to know what the userdata should look like for getting the nodes into the cluster? …I’m not sure if that’s how it works but I think I’m almost to that point. I believe I should have the nodes launching soon but not sure what happens after they go up given the userdata is not windows based.
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
@johnny there is a user-data block passed to the node instance to enable joining the domain, there’s also the aws-auth ConfigMap change required as well to allow the nodes to join. I don’t know the specifics yet but the dev also reported they had trouble getting the Ingress to work initially but worked it out. I still need to determine what his steps to resolve that were
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
Anyone have an idea on which module I need to update this variable in?
module.tf_cloud_builder.module.bucket.google_storage_bucket.bucket: Destroying… [id=]
╷
│ Error: Error trying to delete bucket containing objects without force_destroy
set to true
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
I’d start by looking at source to whatever module is used for tf_cloud_builder
as it appears to be calling the bucket
module that is creating it so may be a variable being passed along
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
Thanks! I started down that path but need to check again
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
The more you work with it reading the state paths make more sense to trace
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
Is there a way to push a variable from the root module down to sub modules?
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
pass as variables to the module and you get outputs from the module
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
does the code need to be re-initialized when you update variables in a module?
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
if the source to module is relative directory based (eg - source = ‘../modules/x’) then no, but if it’s being pulled from a repo or registry yes you will
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
That’s what I cannot figure out for some reason
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
looking at the root module I don’t see any calls to the error module
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
however when I look in the .terraform folder that get created I see many module directories
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
yes the terraform init
process generates the module directories under the .terraform directory
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
if your .tf code has something like:
module "blah" {
source = "../modules/my_module"
...
}
then the terraform init
does not need to be done when the code under ../modules/my_module
is updated or changed.
However if it has something like:
module "blah" {
source = "cloudposse/label/null"
...
}
or any other source that pulls from a Git repo or Terraform registry it does
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
I see the folder for tf_cloud_builder in .terraform directory
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
However I don’t see a folder for module bucket
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
you should not manipulate the .terraform
directory manually… assume it doesn’t exist is safest
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
where is your module "tf_cloud_builder" { ... }
in your working directory
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
there is not one
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
This is the code I executed: https://github.com/terraform-google-modules/terraform-example-foundation/tree/master/0-bootstrap
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
I copied the root folder terraform-example-foundation to my local machine. I changed directories into the 0-bootstrap folder and ran the appropriate TF commands
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
It created the resources
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
Now when I’m trying to delete them is where the problem comes into play
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
it’s in the [cb.tf](http://cb.tf)
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
as
module "tf_cloud_builder" {
source = "terraform-google-modules/bootstrap/google//modules/tf_cloudbuild_builder"
version = "~> 6.2"
project_id = module.tf_source.cloudbuild_project_id
dockerfile_repo_uri = module.tf_source.csr_repos[local.cloudbuilder_repo].url
gar_repo_location = var.default_region
workflow_region = var.default_region
terraform_version = local.terraform_version
cb_logs_bucket_force_destroy = var.bucket_force_destroy
}
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
The variable var.bucket_force_destroy is not being pulled from TF destroy
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
if you’re just trying to perform a terraform destroy
and it’s complaining about not being able to delete the bucket because it is not empty then can you not go into the bucket and delete the objects stored inside it
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
I did that as well
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
still complaining
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
actually I think I may have found it… as I expected the variable is exposed
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
bucket_force_destroy = true
needs to be added to your tfvars
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
I know tfvars exposes variables you define in it, but if a variable is not defined in tfvars. Does TF look at the variables.tf at all?
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
it defaults to false
.. you see it passes var.bucket_force_destroy
as cb_logs_bucket_force_destroy
to the tf_cloud_builder
module which then passes it along to the bucket
module that it calls
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
if you don’t define the variable in tfvars then it gets the default value assigned in the [variables.tf](http://variables.tf)
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
correct and I updated the variables.tf to be true
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
In theory after doing that shouldn’t that have correct the problem?
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
that’s not the ideal way to do it when you’re using someone elses module
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
understood, but just asking for better understanding as I’m still learning TF
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
now TF is complaining that the root module does not declare a variable named buckets_force_destroy
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
you mis-spelled it… it’s not plural bucket_force_destroy
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
fixed that, but still getting the same error from above
data:image/s3,"s3://crabby-images/b07b4/b07b4a005c7269154a2a1c4a6fb2a42fb06053b0" alt="automationtrainee avatar"
module.tf_cloud_builder.module.bucket.google_storage_bucket.bucket: Destroying… [id=tf-cloudbuilder-build-logs-prj-b-cicd]
╷
│ Error: Error trying to delete bucket tf-cloudbuilder-build-logs-prj-b-cicd containing objects without force_destroy
set to true
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
That’s about the extent I can help with them as I don’t use GCE and reading the Terraform repo you gave shows that setting bucket_force_destroy = true
in tfvars passed to it should be passed through to the bucket
module when tf_cloud_builder
calls it in https://github.com/terraform-google-modules/terraform-google-bootstrap/blob/master/modules/tf_cloudbuild_builder/cb.tf#L96
module "bucket" {
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
https://github.com/terraform-google-modules/terraform-example-foundation/blob/master/0-bootstrap/cb.tf#L102 is where tf_cloud_builder
is called and passes the bucket_force_destroy
variable value
cb_logs_bucket_force_destroy = var.bucket_force_destroy
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
What is the greatest lates on TF pipelines lately? How do you run multi tenant/user self serve infra with feature branches in multi account, multi region setups?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Interesting to know on how the pipeline is setup, how the input variables are pass over and how is the user flow
2022-09-16
data:image/s3,"s3://crabby-images/20da6/20da6101f508b111717cfbd5f5cf32162bdeb673" alt="Angela Zhu avatar"
Hey Team, does anyone know why account_id is not part of cloudposse/terraform-cloudflare-zone module?
resource "cloudflare_zone" "example" {
account_id = "f037e56e89293a057740de681ac9abbe"
zone = "example.com"
}
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
How can the account_id help in that module ?
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I believe the account_id
is now implicit in the cloudflare
provider itself
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
so it should be optional to set the account_id
.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
@Angela Zhu do you have a requirement to set an explicit account_id to each module.cloudflare_zone
instantiation ?
data:image/s3,"s3://crabby-images/20da6/20da6101f508b111717cfbd5f5cf32162bdeb673" alt="Angela Zhu avatar"
Hey RB, thanks for quick response. account_id embedding into the provider has been deprecated, it suggests to use specific ’account_id” attributes instead.
data:image/s3,"s3://crabby-images/20da6/20da6101f508b111717cfbd5f5cf32162bdeb673" alt="Angela Zhu avatar"
I do have a requirement to set account_id in each zone
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I don’t think you need to set the account_id
in either the cloudflare
provider or in any of the cloudflare terraform resources anymore.
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
I do have a requirement to set account_id in each zone
may I ask why you need to set this optional argument ?
data:image/s3,"s3://crabby-images/20da6/20da6101f508b111717cfbd5f5cf32162bdeb673" alt="Angela Zhu avatar"
The situation I’m in right now is that I’m migrating from using cloudflare/cloudflare module into using cloudposse/terraform-cloudflare-zone. After I import resources, everything works except that it’s flagging account_id ~> from whatever to null. I can’t confidently push this code because I can’t find documentation on what happens when this is removed. Would it impact member or access_group? It seems to me every zone should have an account_id and zone_id.
data:image/s3,"s3://crabby-images/20da6/20da6101f508b111717cfbd5f5cf32162bdeb673" alt="Angela Zhu avatar"
In their documentation, in only 1 place they mentioned It’s required that an account_id
or zone_id
is provided and in most cases using either is fine.
Everywhere else are just saying this is optional
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
except that it’s flagging account_id ~
from whatever to null.
this should be OK but if you are uncomfortable, feel free to put in a PR to add an optional account_id
with a default value of null
data:image/s3,"s3://crabby-images/20da6/20da6101f508b111717cfbd5f5cf32162bdeb673" alt="Angela Zhu avatar"
I’m testing it in a lower environment right now. I might push a PR for this change. Thanks @RB
2022-09-19
data:image/s3,"s3://crabby-images/fdd60/fdd606d14f70c4c61c0ecdbbf9d22392b73e5553" alt="ghostface avatar"
i have a for_each
for an EKS_node_group resource like below:
resource "aws_eks_node_group" "nodegroup" {
for_each = var.nodegroups
...
how do i ignore all scaling configs for all of the keys?
lifecycle {
create_before_destroy = true
ignore_changes = [scaling_config.[0].desired_size]
}
currently i have the above, am i right in thinking this will only effect the first loop?
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
Hi! Hopefully I can get some direction on my issue.
I am trying to use this module to create an AWS client VPN endpoint, and running into an issue. I cannot avoid getting this error:
│ Error: "name" isn't a valid log group name (alphanumeric characters, underscores, hyphens, slashes, hash signs and dots are allowed): ""
│
│ with module.ec2_client_vpn.module.cloudwatch_log.aws_cloudwatch_log_group.default[0],
│ on .terraform/modules/ec2_client_vpn.cloudwatch_log/main.tf line 17, in resource "aws_cloudwatch_log_group" "default":
│ 17: name = module.log_group_label.id
I have been able to prove something is wrong with this module as if I modify the above referenced line in that file, with a name directly, it works. And I am very confused on how this is working.
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
FWIW I have set logging_stream_name
with a value, but this always gives me this validation error.
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
I have tried names with and without slashes, dashes, and any other allowed chars outside alphanumeric values.
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
Any help is greatly appreciated. I’m pretty much at the point I will need to abandon this module usage as a result of this problem.
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Can you share how you’re instantiating the module?
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
Yeah sure!
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
module "ec2_client_vpn" {
source = "cloudposse/ec2-client-vpn/aws"
ca_common_name = "vpn.mycompany.com"
root_common_name = "vpn-client.mycompany.com"
server_common_name = "vpn-server.mycompany.com"
client_cidr = "10.5.4.0/22"
vpc_id = data.aws_vpcs.mycompany-vpc.ids[0]
organization_name = "mycompany"
name = "client_vpn"
logging_enabled = true
logging_stream_name = "client-vpn/aws-sso-enabled"
id_length_limit = 0
retention_in_days = 90
associated_subnets = ["subnet-idididid"]
self_service_portal_enabled = true
authentication_type = "federated-authentication"
split_tunnel = true
self_service_saml_provider_arn = "arn:aws:iam::ACCTNUMBER:saml-provider/AWSSSOROLE"
authorization_rules = [
{
name = "grant_all"
authorize_all_groups = true
description = "Grants all groups access to the full network"
target_network_cidr = "10.0.0.0/8"
}
]
additional_routes = [
{
destination_cidr_block = "10.0.0.0/8"
description = "Local traffic Route"
target_vpc_subnet_id = "subnet-idididid"
}
]
}
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
https://github.com/cloudposse/terraform-aws-cloudwatch-logs/blob/master/main.tf#L17
If I edit this line in the .terraform
folder, after init and put just my log stream name, it will give me a working plan output.
name = module.log_group_label.id
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
Sorry updated specific submodule.
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
I had a quick look.
I think the issue is the log group not the stream. Most of these modules assume use of context.tf so in this case, module "log_group_label"
has nothing set. You can set variables namespace
, stage
, name
etc or you can use context.tf or the null-label module in your own project and set them there, then pass the reference into module "ec2_client_vpn"
via the context
variable.
The example shows the former.
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
Ah I’ll try that tomorrow morning. Thank you!
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
No worries, let us know how you go!
data:image/s3,"s3://crabby-images/e987d/e987dc587a907c851e2e54be9537e0bcde0774af" alt="Ben Gray avatar"
Joe, that worked! Thank you so much!
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
Hi all, i want to redirect https://example1.example.com to https://example.com/example1 in nginx, if anyone aware of nginx please help me to slove this problem.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
what does this have to do with Terraform? Try #sre
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
but this question seems like something you can solve by googling
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
Ok
2022-09-21
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.3.0 1.3.0 (September 21, 2022) NEW FEATURES:
Optional attributes for object type constraints: When declaring an input variable whose type constraint includes an object type, you can now declare individual attributes as optional, and specify a default value to use if the caller doesn’t set it. For example: variable “with_optional_attribute” { type = object({ a = string # a required attribute b = optional(string) # an optional attribute c = optional(number, 127) #…
data:image/s3,"s3://crabby-images/99f14/99f142c769556c4d75482d90487388acdad54bf3" alt="cool-doge"
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
I have multiple databases in one db instances, how can i backup particular databases in aws, i am using aurora mysql.
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
Hi Folks, I’m experiencing what feels like a fun bug with the Cloudposse Datadog-Lambda-Forwarder Module. For my use case, I’m deploying it to all of our accounts in a centralized workspace using provider blocks. Calling the module multiple times produces an error that calling it a single time does not. Error details and a minimally reproducible code example in :thread: . (Resolved by depends_on
)
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
Error Message:
Error: External Program Execution Failed
with module.datadog_staging_lambda_forwarder.module.forwarder_log_artifact[0].data.external.git[0]
on .terraform/modules/datadog_staging_lambda_forwarder.forwarder_log_artifact/main.tf line 9, in data "external" "git":
program = ["git", "-C", var.module_path, "log", "-n", "1", "--pretty=format:{\"ref\": \"%H\"}"]
The data source received an unexpected error while attempting to execute the program.
Program: /usr/bin/git
Error Message: fatal: not a git repository (or any parent up to mount point /home/tfc-agent)
Stopping at filesystem boundary (GIT_DISCOVERY_ACROSS_FILESYSTEM not set).
State: exit status 128
This should be referencing this line in this module which is called here in the main module.
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
Minimal code example:
module "datadog_prod_lambda_forwarder" {
source = "cloudposse/datadog-lambda-forwarder/aws"
# Cloud Posse recommends pinning every module to a specific version
version = "0.12.0"
forwarder_log_enabled = true
cloudwatch_forwarder_log_groups = {
some_group = {
name = "<path to a log group>",
filter_pattern = ""
},
some_other_group = {
name = "<path to a log group>"
filter_pattern = ""
}
}
dd_api_key_source = var.prod_dd_api_key_source
dd_tags = []
providers = {
aws = aws.prod
}
}
module "datadog_staging_lambda_forwarder" {
source = "cloudposse/datadog-lambda-forwarder/aws"
# Cloud Posse recommends pinning every module to a specific version
version = "0.12.0"
forwarder_log_enabled = true
cloudwatch_forwarder_log_groups = {
some_group = {
name = "<path to a log group>",
filter_pattern = ""
},
some_other_group = {
name = "<path to a log group>"
filter_pattern = ""
}
}
dd_api_key_source = var.staging_dd_api_key_source
dd_tags = []
providers = {
aws = aws.staging
}
}
provider "aws" {
region = "us-west-2"
alias = "prod"
assume_role {
role_arn = var.prod_role_arn
session_name = "Terraform"
external_id = var.prod_aws_external_id
}
access_key = var.prod_aws_access_key
secret_key = var.prod_aws_secret_key
}
provider "aws" {
region = "us-west-2"
alias = "staging"
assume_role {
role_arn = var.staging_role_arn
session_name = "Terraform"
external_id = var.staging_aws_external_id
}
access_key = var.staging_aws_access_key
secret_key = var.staging_aws_secret_key
}
Provider should work without assume_role if you use access/secret keys into the specific accounts, I kept it as close to my implementation as possible just on the outside chance this is related (Although i doubt it).
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
And to note: I can get any of the modules to work if I comment out the others, I’ve attempted it with 1, 2, and 3 modules. With 1, it works (no matter which), with 2, one will fail, with 3, two will fail. I haven’t tested it with 4+, but I think it’s reasonable to assume it will be n-1 failures.
Oh, and: this is executed via terraform cloud, if that makes a big difference.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/f5393/f5393a0c9f0ffb642ee72180de2073dea1f5d863" alt="Ben Smith (Cloud Posse) avatar"
That’s pretty odd, taking a look now
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
It’s possible that this might be related to the -C
flag in the git command, and if it’s run multiple times. From the git documentation:
-C
Run as if git was started in _ _ instead of the current working directory. When multiple `-C` options are given, each subsequent non-absolute `-C ` is interpreted relative to the preceding `-C `. If _ _ is present but empty, e.g. `-C ""`, then the current working directory is left unchanged. This option affects options that expect path name like `--git-dir` and `--work-tree` in that their interpretations of the path names would be made relative to the working directory caused by the `-C` option. For example the following invocations are equivalent: git --git-dir=a.git --work-tree=b -C c status git --git-dir=c/a.git --work-tree=c/b status
I’m frankly not sure if running (
var.module_path
collapsed to${path.module}
per this line):git -C ${path.module} log -n 1 --pretty=format:{"ref": "%H"}
or the properly escaped equivalent multiple times would essentially stack deeper and deeper and be problematic, or if this is otherwise potentially related to path.module and the terraform warning: We do not recommend usingpath.module
in write operations because it can produce different behavior depending on whether you use remote or local module sources. Multiple invocations of local modules use the same source directory, overwriting the data inpath.module
during each call. This can lead to race conditions and unexpected results. If that’s the case, it’s possible I may be able to avoid this by usingdepends_on
to ensure each module fully completes before the next one attempts to run. I’m going to give that a try right now.
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
Yep, using depends_on
to ensure each module finishes before the next starts resolved the issue. It’s likely related to path.module
.
data:image/s3,"s3://crabby-images/f5393/f5393a0c9f0ffb642ee72180de2073dea1f5d863" alt="Ben Smith (Cloud Posse) avatar"
Gotcha, glad that unblocked you, I’ll add this to our notes, I know we’ve been seeing some more git -C
issues recently, maybe theres a way to avoid it or clean it up
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
Unfortunately while running the apply (rather than just plan) this morning, it came back. depends_on
appears to resolve the plan-time error, but they don’t run properly.
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
Looks like s3 bucket replication of existing objects is not currently supported by latest AWS provider (4.31).
So my best option seems to be to first run terraform apply to put new-object replication in place for desired buckets, then run a Batch Replication job from CLI using aws s3control create-job ...
on each bucket (since I have a lot of buckets to replicate existing objects, and replication jobs require a replication config to already exist).
But then it is easy to forget to run that script after terraform apply, so better:
• Add a local-exec
provisioner to the bucket replication config resource in my tf code, with when=create
. But this would get skipped for buckets that already have replication config (ie already created).
• Better add that provisioner to a null_resource
that is enabled only if a variable is set to true (and no when
set). I would set it to true, apply, set it to false, push.
Any considerations I might be forgetting?
data:image/s3,"s3://crabby-images/960b2/960b22776c71458036b0a3f985dd4329c033580f" alt="Denis avatar"
I just enabled replication through terraform, and used the Batch jobs to replicate the existing objects initially. After that the replication rule is resuming as expected. But I only had to do that for 10 S3 buckets so the initial manual step was not that time consuming for me.
data:image/s3,"s3://crabby-images/4b79c/4b79cb3ac4d33ded2b752b1679ba680cf5687cb9" alt="Jeremy (UnderGrid Network Services) avatar"
Anyone looked at updating the terraform-aws-elasticsearch module to support OpenSearch or creating a new module for it?
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
Hey all, I’m trying to set up a new AWS organization and accounts with the terraform-aws-components/account
module but running into an odd issue on the atmos terraform plan
:
│ Error: error reading Organizations Policy (p-9tkedynp): AWSOrganizationsNotInUseException: Your account is not a member of an organization.
│
│ with module.organizational_units_service_control_policies["platform"].aws_organizations_policy.this[0],
│ on .terraform/modules/organizational_units_service_control_policies/main.tf line 37, in resource "aws_organizations_policy" "this":
│ 37: resource "aws_organizations_policy" "this" {
Yeah I’m not a member of an organization, my impression is the account module is supposed to create the organization no? (Resolved by terraform clean)
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
This is my component in the atmos stack:
components:
terraform:
account:
vars:
enabled: true
account_email_format: aws+%[email protected]
account_iam_user_access_to_billing: DENY
organization_enabled: true
aws_service_access_principals:
- cloudtrail.amazonaws.com
- guardduty.amazonaws.com
- ipam.amazonaws.com
- securityhub.amazonaws.com
- servicequotas.amazonaws.com
- sso.amazonaws.com
- auditmanager.amazonaws.com
- ram.amazonaws.com
enabled_policy_types:
- SERVICE_CONTROL_POLICY
- TAG_POLICY
service_control_policies_config_paths:
- "../aws-service-control-policies/catalog/organization-policies.yaml"
organization_config:
root_account:
name: core-root
stage: root
tenant: core
tags:
eks: false
accounts: [ ]
organization:
service_control_policies: [ ]
organizational_units:
- name: platform
accounts:
- name: platform-dev
tenant: platform
stage: dev
tags:
eks: false
- name: platform-staging
tenant: platform
stage: staging
tags:
eks: false
- name: platform-prod
tenant: platform
stage: prod
tags:
eks: false
service_control_policies:
- DenyLeavingOrganization
- name: core
accounts:
- name: core-audit
tenant: core
stage: audit
tags:
eks: false
- name: core-data
tenant: core
stage: data
tags:
eks: false
- name: core-dns
tenant: core
stage: dns
tags:
eks: false
- name: core-identity
tenant: core
stage: identity
tags:
eks: false
- name: core-network
tenant: core
stage: network
tags:
eks: false
- name: core-security
tenant: core
stage: security
tags:
eks: false
service_control_policies:
- DenyLeavingOrganization
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
This error was magically resolved by terraform clean and deleting the state
2022-09-22
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
Hey all, is there any tool for convert cloudformation to terraform ??
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
data:image/s3,"s3://crabby-images/a4e68/a4e68e34f10c8b4ea55eb1bf537d97c20e184816" alt="kirupakaran avatar"
Yeah, but i haven’t seen any proper tool
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Convert Cloudformation templates to Terraform.
2022-09-23
data:image/s3,"s3://crabby-images/2ba75/2ba758646eeccff11ba41adc308dd617306a9ca8" alt="Herman Smith avatar"
Is it possible to have a terraform module enforce that the aws provider it inherits is configured to a certain region? (And fail if a provider for a different region is in use)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
no, I do not think is possible
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
since the provider can use ENV variables to be configured
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it supports the same aws ENV variables so if you do it in you module, you can still set the AWS_REGION var to whatever and workaround the hardcoded region
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is that what you mean?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
or you are asking if you can create resources in your module for another region?
data:image/s3,"s3://crabby-images/2ba75/2ba758646eeccff11ba41adc308dd617306a9ca8" alt="Herman Smith avatar"
I don’t want to violate the module user’s expectations and operate in a different region to what they asked - just want to let them know “you can only use this module in <X> region”
data:image/s3,"s3://crabby-images/2ba75/2ba758646eeccff11ba41adc308dd617306a9ca8" alt="Herman Smith avatar"
Ah, looks like configuration_aliases
in required_providers
would essentially enable me to restrict to a given provider alias (named by region), that should suffice
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ohhh cool
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
When you use configuration_aliases
, it acts as though you have n+1 providers, as it assumes configuration_aliases = ["us-west-2"]
is equal to two providers: aws
and aws.us-west-2
. I’ve experienced strange issues when only passing in a single provider to it (providers = { aws.us-west-2=aws }
) and not passing in the aws=...
provider as well.
You may wish to look into using something like data "aws_region" "current" {}
and validate data.aws_region.current.name == myregion
. I haven’t used it in this manner myself though, so you should experiment with both methodologies and see how they work in practice.
data:image/s3,"s3://crabby-images/2ba75/2ba758646eeccff11ba41adc308dd617306a9ca8" alt="Herman Smith avatar"
Thanks @Julian Olsson. Worked perfectly with a lifecycle postcondition!
data:image/s3,"s3://crabby-images/3cb34/3cb34c4c1f6ef54c574587f4daee19b877c68722" alt="Julian Olsson avatar"
The data "aws_region"
variant, I assume? If so, excellent, thanks for letting me know it works, I’ll keep that one in my back pocket for another day.
data:image/s3,"s3://crabby-images/2ba75/2ba758646eeccff11ba41adc308dd617306a9ca8" alt="Herman Smith avatar"
Yes, exactly. And me too!
data:image/s3,"s3://crabby-images/35880/35880599f44d07872b39b4fea0e6bf991397dfc0" alt="Mazin Ahmed avatar"
I have this issue where I can not run terraform import
on a new remote state within TFE at a workspace. It’s a new workspace and does not have resources yet, I am trying run import script before merging a PR for all tf resources. Any ideas how to solve this?
Acquiring state lock. This may take a few moments...
Failed to persist state: Error uploading state: resource not found
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Create the state with one dummy resource, then run your imports?
data:image/s3,"s3://crabby-images/ee773/ee77365d793dc5059e7c54cd2456664abf4fee52" alt="Chris Dobbyn avatar"
If runner based, just upload blank TF code and let an empty plan/apply run. Then add the stuff you want to import.
data:image/s3,"s3://crabby-images/ee773/ee77365d793dc5059e7c54cd2456664abf4fee52" alt="Chris Dobbyn avatar"
Make sure you’ve got workspace configured in the cloud block.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
TFC Cloud pricing question: anyone know the actual price?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I asked few people and said there is a cost per state
( workspace) , per user and per run?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
as usual website is not very detailed…..
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Talking Terrafrom Cloud SaaS not Enterprise
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I want to confirm it is a real per user only cost
data:image/s3,"s3://crabby-images/ee773/ee77365d793dc5059e7c54cd2456664abf4fee52" alt="Chris Dobbyn avatar"
If you sign up (free) and look at the usage tab, it’ll give you everything you need to know.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we are on the free
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but we need to forecast price so we need to have an idea on how to calculate the price
data:image/s3,"s3://crabby-images/ee773/ee77365d793dc5059e7c54cd2456664abf4fee52" alt="Chris Dobbyn avatar"
I’m not sure re. the normal cloud one. It may be worthwhile setting up a meeting with them to establish cost estimates.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Basically it’s bespoke depending on your negotiating power. Think like new relic
data:image/s3,"s3://crabby-images/78701/78701e63b3ea513290fca8a066c55cba3d3cb90b" alt="this"
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I just had bad experiences with Hashicorp sales every single time
data:image/s3,"s3://crabby-images/ee773/ee77365d793dc5059e7c54cd2456664abf4fee52" alt="Chris Dobbyn avatar"
They’re not super great (cost wise for features you get), I wouldn’t recommend if you are able to use any others.
data:image/s3,"s3://crabby-images/62ea3/62ea3a0f57be2a1b9349cb1d798270aab599c544" alt="Alex Jurkiewicz avatar"
Yes I think the process is to delay giving you a quote for as long as possible until they can figure out what you can afford
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
per user
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this guys have been useless to say the least….
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
they keep asking for a number, like asking “tell me how much money you have, I will charge you that”
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
what kind of sale tactic is that? I do not know, but I do not like it
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
Depends on your negotiating power. I had one customer who had to pay $50 per apply when using a tf cloud runner. That goes away when you use your own runner when you use tfcloud solely to manage state and workspace configuration, or you use the tfcloud agent to operate your own fleet of runners on your own hardware.
data:image/s3,"s3://crabby-images/393bc/393bccf74260bf8111a7c988a36a747eba2b7977" alt="Fizz avatar"
I think you would want to run your own runners anyway, solely to manage the principal used to run tf better, e.g. aws access key when running in tf cloud vs aws role when running your own runner.
2022-09-24
2022-09-26
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
I have a stack that will consist of N tfstates. I could easily write an N-line bash script to do tf apply on each one, but I’m wondering if one of terragrunt, terramate, terraspace or cdktf might have good support for this and aspects of such design that I might now yet realize
Eg N-1 of those states will be completely independent one another and will depend only on the first module (which is a base layer), so technically they could all be updated in parallel. Does one of these tools support describing the stack in terms of separate states, and the dependencies of module on other modules, then it could automatically figure out the order of tf applies and do some in parallel.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
terragrunt and terramate both handle that scenario. i find it rather hard to parse outputs of either though, when running against multiple stacks in parallel. easy to lose/miss something in review
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
any reason in particular?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
better visibility of the changeset
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
if you must roll your own CICD automation solution, here is a new tool that attempts to help you figure out the order of operations… https://github.com/contentful-labs/terraform-diff
Always know where you need to run Terraform plan & apply!
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
if you’re using github and github actions, there’s also tfcmt to post plan results back to github pull requests… https://github.com/suzuki-shunsuke/tfcmt
Fork of mercari/tfnotify. tfcmt enhances tfnotify in many ways, including Terraform >= v0.15 support and advanced formatting options
data:image/s3,"s3://crabby-images/e6209/e6209fb441ae1a71cc9575744231254abff00850" alt="OliverS avatar"
Thanks @loren for the suggestions
2022-09-27
data:image/s3,"s3://crabby-images/6fb86/6fb865370027e5a1158398158d85734887beee8a" alt="Konrad Bloor avatar"
Just got to say, as someone new to terraform trying to build infrastructure quickly for a new venture, cloudposse terraform modules rule, wow. Thanks
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
Has cloudposse developed any module/components for AWS ipam? I’m looking into using IPAM instead of working out all the IP blocks in a spreadsheet
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
We don’t but we’ve created a root terraform module (component) that wrapped this module
Terraform Module for create AWS IPAM Resources
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
Thanks
2022-09-28
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
Has anyone setup centralized egress for all your VPCs through the network account, via an NAT gateway, using cloudposse terraform-aws-components? I’m using transit gateway but it looks like that would require a lot of changes to the tgw components’ route configs.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’re building out this architecture right now for another customer
data:image/s3,"s3://crabby-images/fdd60/fdd606d14f70c4c61c0ecdbbf9d22392b73e5553" alt="ghostface avatar"
out of curiosity, why would you want to do this?
data:image/s3,"s3://crabby-images/15b5a/15b5adba73c8bcfe4613f4116dacb67157dab55b" alt="Ray Botha avatar"
Mostly centralized control/monitoring of traffic, and cost. https://docs.aws.amazon.com/whitepapers/latest/building-scalable-secure-multi-vpc-network-infrastructure/centralized-egress-to-internet.html https://aws.amazon.com/blogs/networking-and-content-delivery/creating-a-single-internet-exit-point-from-multiple-vpcs-using-aws-transit-gateway/
As you deploy applications in your Landing Zone, many apps will require outbound only internet access (for example, downloading libraries, patches, or OS updates).
data:image/s3,"s3://crabby-images/0ea9e/0ea9e24f357b247e53147143f8db41d5575005a1" alt="attachment image"
In this post, we show you how to centralize outbound internet traffic from many VPCs without compromising VPC isolation. Using AWS Transit Gateway, you can configure a single VPC with multiple NAT gateways to consolidate outbound traffic for numerous VPCs. At the same time, you can use multiple route tables within the transit gateway to […]
data:image/s3,"s3://crabby-images/78701/78701e63b3ea513290fca8a066c55cba3d3cb90b" alt="this"
data:image/s3,"s3://crabby-images/8a381/8a3810bd25852254138ad01824f62424958b5723" alt="setheryops avatar"
Any recs on apps for detecting drift in Terraform if you are NOT on Terraform cloud? Every place ive worked we have always had an internally developed custom app. I really dont want to have to write another one again for my current gig.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
driftctl?
data:image/s3,"s3://crabby-images/8a381/8a3810bd25852254138ad01824f62424958b5723" alt="setheryops avatar"
Interesting…ill check it out. Thx
data:image/s3,"s3://crabby-images/8a381/8a3810bd25852254138ad01824f62424958b5723" alt="setheryops avatar"
Just an fyi for anyone else that pokes their head in this thread…its found at [docs.driftctl.com](http://docs.driftctl.com)
not just [driftctl.com](http://driftctl.com)
<– That takes you to a wordpress login
data:image/s3,"s3://crabby-images/4d0f1/4d0f1fa0dc7f02aba45f523f7aad8017e61242c0" alt="Lee Broom avatar"
Any recommendations for a good guide on deploying cloudposse modules into own projects?
data:image/s3,"s3://crabby-images/840f2/840f20f95264f61befe3a4f5d9f7a85f08f3726c" alt="Release notes from terraform avatar"
v1.3.1 1.3.1 (September 28, 2022) NOTE: On darwin/amd64 and darwin/arm64 architectures, terraform binaries are now built with CGO enabled. This should not have any user-facing impact, except in cases where the pure Go DNS resolver causes problems on recent versions of macOS: using CGO may mitigate these issues. Please see the upstream bug <a class=”issue-link js-issue-link” data-error-text=”Failed to load title” data-id=”1231779689” data-permission-text=”Title is private”…
data:image/s3,"s3://crabby-images/46ed8/46ed89dd5fa817f7ff21417e36a239010f1577d1" alt="Tim Schwenke avatar"
Hey everyone, I have a question regarding terraform-null-label: I get how to use it as a module. But do I also include the [context.tf](http://context.tf)
in my own files if I’m writing a module myself (which I do all the time because everything in Terraform is a module)? Basically replicating what Cloud Posse is doing within their own modules.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
[context.tf](http://context.tf)
has all the context variables used by the label module (and other things)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you include it, you don’t have to provide all those variables
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
our pattern is to always include [context.tf](http://context.tf)
and don’t think about those common vars that are used by all modules and components
data:image/s3,"s3://crabby-images/46ed8/46ed89dd5fa817f7ff21417e36a239010f1577d1" alt="Tim Schwenke avatar"
Okay, that helps. Thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/18f79/18f79ab556da29240abc390847f0b6b5aec7be69" alt="Thomas Panicker avatar"
Is there anyone out there interested in upgrading TF 0.12 to something more current..
data:image/s3,"s3://crabby-images/f1434/f143469954cea5cc381eb57bc7ad9f6d5df71d5f" alt="mikesew avatar"
We just upgraded some of our terraform workspace/configs to 0.13. from there on, upgrading to further versions beyond was fairly easy (no major syntax changes). any questions in particular?
data:image/s3,"s3://crabby-images/7a050/7a0502428e428e7c6930fd927f0e6d06ea418c0b" alt="Nitin avatar"
Hello Team,
How can remove a resouce created using cloudposse/vpc-peering-multi-account/aws
data:image/s3,"s3://crabby-images/7a050/7a0502428e428e7c6930fd927f0e6d06ea418c0b" alt="Nitin avatar"
we don’t need vpc peering.. what is the best way to do it.
data:image/s3,"s3://crabby-images/7a050/7a0502428e428e7c6930fd927f0e6d06ea418c0b" alt="Nitin avatar"
because if i delete it and then plan and apply it is faling
data:image/s3,"s3://crabby-images/7a050/7a0502428e428e7c6930fd927f0e6d06ea418c0b" alt="Nitin avatar"
if i set enable = false then authorization issue is coming
data:image/s3,"s3://crabby-images/4d072/4d0722b6aa230593938f89dc1b4f0b9bab35e181" alt="RB avatar"
@Nitin Could you create an issue for this on the module?
For now you could do a targeted destroy
terraform destroy -target module.peering