#terragrunt (2019-05)
Terragrunt discussions
Archive: https://archive.sweetops.com/terragrunt/
2019-05-08
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
Is it me or do the terragrunt docs seem lacking? I’ve been having to dig through git issues to find out more. Any external doc references are appreciated
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Maybe try https://community.gruntwork.io/
The Community Forum for Gruntwork customers
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
thank you
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we (cloudposse) don’t use terragrunt
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I really think the tool is great for what it’s trying to do, it’s just a bit frustrating
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
yeah - having used terragrunt where i’m currently working, i can’t recommend it again. it’s very opinionated in how modules are created and used with the “source=” stuff in the tfvars file.
trying to have more than 1 module in a state when not everything is copied to the “.terragrunt-cache” directory really annoyed me.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
@Jonathan Le I thought each module in terragrunt was supposed to have it’s own state file? What were you trying to accomplish with multiple modules in a single state file?
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
You are right - each state should be it’s own module. Like 1 module per app/stack.
For me, TG and this method caused me to have a lot of copy/paste between modules though.
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
Like, there’d be a basic model of what an EC2 instance was to me and it would have been great to have this as a module like I had without TG.
I had to copy/paste between the resource configuration between similar TG modules to pull them off and the tradeoff really annoyed me.
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
It was great to have cool stuff like the following to try to keep things “dry”:
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
but the very similar resource config across TG modules was super duper annoying.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
yeah that doesn’t look fun
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
are you talking about sharing stuff between modules too?
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
not sure what you mean about “sharing stuff between modules”. if you mean about datasources between the different module states, that works fine with TG.
if you mean about trying to stay DRY, i didn’t feel i was able to with TG.
e.g, I have very similar looking resource config for ec2 instances across various modules:
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
ahhhh we’re using a segregated ec2 module, we’re not embedding it into other modules as part of a full “service”
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
what do you guys use?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terraform natively supports intialization of projects using the -from-module
parameter
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you can pass that as an environment variable too
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
TF_CLI_ARGS_init=-from=module=....
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we define all of our root module invocations here: https://github.com/cloudposse/terraform-root-modules
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we wrote an “env mapper” to make setting envs for terraform easier (but it’s not required)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Transform environment variables for use with Terraform (e.g. HOSTNAME
⇨ TF_VAR_hostname
) - cloudposse/tfenv
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
here’s how we put it together:
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the .envrc
indicates the module we want to use
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then we just call terraform init
and it automatically imports the remote module
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
no wrappers required
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
25 votes and 10 comments so far on Reddit
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
damn that’s nice
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I was worried about what happens when terraform is updated when using terragrunt
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
I’m gonna need to dig through all of this
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, that’s what i like about this.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
what about all the state stuff that terragrunt does for you, how are you guys handling that?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terragrunt is basically a task runner
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
there are a lot of task runners out there.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use make
predominantly with terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terragrunt
helps keep your code DRY, but if you decompose thee different things that terragrunt does, you can easily accomplish it other ways
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use direnv
to keep project level settings
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use make
for a task runner
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use tfenv
to make mapping envs easier (totally optional)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we use terraform init -from-module=...
(using the TF_CLI_ARGS_init=-from-module=...
env), to keep things DRY.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Whats the use for -from-modules=
I never understood this workflow. Could you elaborate?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This allows you to bootstrap modules. Terragrunt uses it (if you look under the hood) too.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So in our case, we have a central catalog of “root” modules. Every time we merge to master, we cut a release.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
When we want to use that module for an environment (e.g. prod) we call terraform init with -from-module to download it. That way we never copy/paste the code. It also allows us to have different environments pinned to different versions.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terragrunt does the same thing. Only it writes it to a cache folder
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Thanks, that part was clear tho, but why not just
module "this" {
source = "sourcelink"
vars = "that"
}
sort of thing
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
what is the advantage?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the combination of these things create a generalizable pattern that works formore than terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for example, we use helm
and helmfile
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we package all the tools in geodesic
, which is our cloud automation image
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Geodesic is a cloud automation shell. It's the fastest way to get up and running with a rock solid, production grade cloud platform built on top of strictly Open Source tools. ★ this repo! h…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we also use variant
to define cli tools specific to our organization.
data:image/s3,"s3://crabby-images/80fd8/80fd89c51f0544da744d6b75648e1d4eca118896" alt="bananadance"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Wrap up your bash scripts into a modern CLI today. Graduate to a full-blown golang app tomorrow. - mumoshu/variant
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We have lots of examples of variant in use here: https://github.com/cloudposse/geodesic/tree/master/rootfs/usr/local/bin
Geodesic is a cloud automation shell. It's the fastest way to get up and running with a rock solid, production grade cloud platform built on top of strictly Open Source tools. ★ this repo! h…
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
this is all really good stuff to take back to my team
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cool! happy to share more or answer any questions.
data:image/s3,"s3://crabby-images/ee80b/ee80b5ce198382c5396b69608798b06ab237a9d4" alt="Joe Perez avatar"
this is a great start, thank you
2019-05-31
data:image/s3,"s3://crabby-images/bd3f2/bd3f23a777453310d6837ca6cd70384b513fdaa7" alt="Meb avatar"
Thanks for the feedbacl & Rex. Good call on these