#terragrunt (2021-02)
Terragrunt discussions
Archive: https://archive.sweetops.com/terragrunt/
2021-02-09
data:image/s3,"s3://crabby-images/b4d58/b4d5873c7ad577cf78d4cd0686a7458cbba5957e" alt="Amit Karpe avatar"
Do we have AWS Profile option using Terragrunt?
I am ware that using Terraform, we can use provider block:
provider "aws" {
profile = "default"
region = "us-west-2"
}
Where we can specify profile name.
How I can change that in the terragrunt.hcl?
Is there any way we can override it during terragrunt apply
or any run time operation?
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
remote_state {
backend = "s3"
config = {
bucket = "foo-bar-tfstate"
key = "<tfstatename>.tfstate"
region = "us-east-1"
encrypt = true
profile = "<aws-profile-name>"
}
}
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
Something like this ?
data:image/s3,"s3://crabby-images/b4d58/b4d5873c7ad577cf78d4cd0686a7458cbba5957e" alt="Amit Karpe avatar"
Got it Thank you I was able to use given suggestion
2021-02-10
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Am new to Terragrunt. Trying to run Cloudrail as part of my Terragrunt flow to test plans before they are applied. I have three modules - item1
, item2
, item3
. Cloudrail needs to take in the plan.out out as its input, and spits out some stdout content as well as an exit code. Based on this exit code, I want to move forward to apply.
So am running this:
terragrunt run-all plan -out plan.out
terragrunt run-all apply -auto-approve plan.out
And I’ve added this after_hook:
terraform {
after_hook "cloudrail_after_hook" {
commands = ["plan"]
execute = [
"docker",
"run",
"--rm",
"-v", "${get_env("PWD", "")}:/data",
"indeni/cloudrail-cli",
"run",
"-d", "${path_relative_to_include()}",
"--tf-plan", "${path_relative_to_include()}/plan.out",
"--origin", "ci",
"--build-link", "<https://somelink>",
"--execution-source-identifier", "somebuildnumber - tg module ${path_relative_to_include()}",
"--api-key", "${get_env("CLOUDRAIL_API_KEY", "")}",
"--auto-approve"
]
}
}
But:
- The execution of the Cloudrail container is all over the place. It’s hard to know which module the Cloudrail output belongs to without using
--terragrunt-log-level info
. - The whole concept of passing to apply a plan I created in a previous step doesn’t seem to be working. Am I missing something?
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
@Mohammed Yahya help!!!
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
the -all
commands are a hot mess. it’s a nice idea, but seems to only work in very restrictive use cases
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
So if you have multiple modules, you run each plan separately?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
personally, yes, i manage that execution/orchestration outside terragrunt.
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
In that case, a simple plan -out plan.out
(with after_hook) and apply plan.out
, just done multiple times.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
yes, exactly
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i also agree on the terragrunt output being interleaved and difficult to understand when using -all
… i have an open issue for addressing it… https://github.com/gruntwork-io/terragrunt/issues/1194
Right now, all terraform output is unmodified, which makes a lot of sense for regular terraform commands because they are only working on one config at a time and the output can be captured/used fo…
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Ah! I was looking for the same thing. This interleaving was messing with my mind.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i got so sick of it, i had to write a custom command runner to inject the paths for our own usage i’d try to fix it in terragrunt, but golang makes my head hurt
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
python asyncio ftw!
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Amen to that
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
semi-related, absolute paths are too noisy… https://github.com/gruntwork-io/terragrunt/issues/1515
Instead of showing absolute paths, is it possible to make Terragrunt's console output show paths relative to where the command was run? For example, commands like validate, validate-all, plan e…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Also, the change adding –terragrunt-log-level is very new, and there is a new pr making “info” the default, basically reverting the output back to before they had log levels… Basically, output of -all is a work in progress
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
One thing you can try, is to redirect the cloudrail output to a known location, with a filename based on the terragrunt-working-dir, so you can review it afterwards
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Oh yeah that could work too. There’s the --output-file
and --output-format
options for Cloudrail.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Don’t use plan-all / apply-all
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
not production safe
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
@Yoni Leitersdorf (Indeni Cloudrail) first make it more simple by creating a function alias in .bashrc
or .zshrc
as this example:
slscan() {
docker run --rm -e "WORKSPACE=$(pwd)" -e GITHUB_TOKEN -v "$(pwd):/app" shiftleft/scan scan $*
}
add there what ever logic you need,
then cal slscan
in your terragrunt
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
IMHO I’m using a Taskfile (modern Makefile alternative) for all the logic I need before calling Terraform or Terragrunt, example:
task init
task plan # this will write plan.out
task cloudrail # this will read/scan plan.out
task apply # this will apply plan.out
task inframap # this will draw plan.out
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Why wrap Terrragrunt (a wrapper) in another wrapper?
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
Good one, but when you work so deep with IaC you need your own wrapper
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Not true
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
I don’t use Terragrunt anymore, I’m using my own
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
Universal Tool for DevOps and Cloud Automation (works with terraform, helm, helmfile, istioctl, etc) - cloudposse/atmos
CLI Tool to help with various automation tasks (mostly all that stuff we cannot accomplish with native terraform) - cloudposse/turf
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
you reach a point where you have complex logic and need your own tool
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
I agree with you but the point is all of these tools are just wrapper around Terraform, so used what ever you prefer, and match your use case
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Need a tool, don’t need own tool….
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Using Terragrunt/Atlantis without issues on a large codebase, multi region, multi account …
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I’d rather take something sane off the shelf, than build your own and have to write fancy bespoke adapters for everything
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Thank you for the feedback everyone. I feel much better now (I thought it was me!).
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
atlantis is nice, but you still need to run it and maintain it. it’s not actually free. a cli wrapper can run in any existing CI or local system, and doesn’t consume resources when not in use. most of our implementations are in codecommit, with event hooks to trigger codebuild
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
so pros and cons both ways
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
@Yoni Leitersdorf (Indeni Cloudrail) might be worth revisiting the -all
workflow… terragrunt has published a few versions already that are trying to address some of your pain….
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Yeah I noticed
data:image/s3,"s3://crabby-images/f9865/f9865f3d4e421dd840f4c2ad0086f10b2f2e34ee" alt="Yoni Leitersdorf (Indeni Cloudrail) avatar"
Did you give it a shot?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i have not… my workflows tend to avoid -all
…
data:image/s3,"s3://crabby-images/23935/239350eb34c40aabaa5b8d39f50b1e5d205c4294" alt="Mohammed Yahya avatar"
@Mohammed Yahya has joined the channel
2021-02-11
data:image/s3,"s3://crabby-images/f7dde/f7ddea92259898f4c2b7b79e82166ef435324d7b" alt="Asis avatar"
Hi Everyone Our team runs terragrunt modules locally , what are the best solutions/ practice to run modules in more unified pattern Note we have s3bucket + dynamodb for locking state Thanks in Advance
data:image/s3,"s3://crabby-images/1984b/1984b447012f44da2787262a5a693a3468dfbc94" alt="omry avatar"
hi @Asis - you can give env0 a try, we support deployments and running terragrunt and terraform modules in a unified solution. You can read mode here - https://www.env0.com/
- Disclaimer - I am the co-founder and CTO of env0.
data:image/s3,"s3://crabby-images/75d3e/75d3e56c51fec4cc3f37674861e74da64f6e8e0a" alt="attachment image"
Automate the provisioning of Terraform workflows and Infrastructure as Code with env0. Get visibility, predictability and governance on your cloud deployments.
2021-02-17
2021-02-26
data:image/s3,"s3://crabby-images/5fae3/5fae346aa2b564d257832cbb47906c3064b7ec90" alt="Tim Gourley avatar"
Hi All, I’ve been looking at Atlantis for automation with our Terragrunt configurations. The recommended approach seems to be to plan individual projects. Atlantis can do some parallel operations but it is real fuzzy to me if that actually works (workspaces get pulled into the conversation etc) I have a test configuration with about 24 modules and the Atlantis plan takes ~30 minutes since it processes each model in sequence. I did get some parallel operations but then there were lock contentions, and the workspace topic freaks me out as I understood that is not something you do when using Terragrunt.
So, what am I missing, am I using a hammer to drive a screw? Why is plan-all not discussed? I do understand the shortcomings of unapplied modules affecting dependent modules in the plan but I think this is one of the choices we make when we move to Terragrunt. Any suggestions on a more appropriate automation tooling for Terragrunt managed envs?
TIA, Tim
data:image/s3,"s3://crabby-images/841c4/841c4b09102f89356b37b782ba067539e37de573" alt="ohad avatar"
Check out env0 support of Terragrunt - https://www.env0.com/blog/terragrunt-release (disclaimer - I am co-founder and CEO of env0)
data:image/s3,"s3://crabby-images/98b33/98b33d529a503586447790721b41ab4cffc853c1" alt="attachment image"
Hello, env0 and Terragrunt fans alike! It’s new-feature-day, yet again! But this time, we have something really special for you. We’re giving you the ability to completely change the game on the Infrastructure as Code files that you use to deploy and manage environments with our platform! Introducing remote-run support for Terragrunt workflows, now available in env0!
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
You can also still use Atlantis and just use https://github.com/transcend-io/terragrunt-atlantis-config to automatically make atlantis work for terragrunt with parallelization and automatic atlantis.yaml
generation so that all affected modules are planned
Generate Atlantis config for Terragrunt projects. Contribute to transcend-io/terragrunt-atlantis-config development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/5fae3/5fae346aa2b564d257832cbb47906c3064b7ec90" alt="Tim Gourley avatar"
I tried the terragrunt-atlantis-config and it did not seem help much. Isn’t atlantis still going to process modules individually and sequentially?
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
If you use the --parallel
and ``–create-workspace` flags it will process in parallel. I have about 600 terragrunt modules that can all be planned in about 15 minutes
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
Generate Atlantis config for Terragrunt projects. Contribute to transcend-io/terragrunt-atlantis-config development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
There is a concept of Atlantis workspaces, and there is a concept of terraform workspaces, but they are entirely unrelated, so --create-workspace
is safe to use. It only refers to creating Atlantis workspaces
data:image/s3,"s3://crabby-images/5fae3/5fae346aa2b564d257832cbb47906c3064b7ec90" alt="Tim Gourley avatar"
Thanks for the responses! I’ll give this another go…
2021-02-28
data:image/s3,"s3://crabby-images/fd255/fd2553b53316841775f207441b2bc4fbbd93c4aa" alt="Christian avatar"
How do you guys structure your folders when dealing with iam users in terragrunt? One terragrunt.hcl file per iam user?
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
I have one module that makes all users, and then I have separate IAM role modules that assign users to roles