#terragrunt (2020-09)
Terragrunt discussions
Archive: https://archive.sweetops.com/terragrunt/
2020-09-08
data:image/s3,"s3://crabby-images/6ddbe/6ddbe14aa8f3190e4e4f2a16781590d3ed35fd6c" alt="jason einon avatar"
hey all, ive been working with terragrunt for a while now.. just moving some automation into a jenkinsfile job to deploy from a jenkins… however getting errors when pulling for remote private repo, has anyone implemented this ? example source and error below:
terraform {
source = "git::<ssh://[email protected]/company/paas-multi-terraform-library.git//gcp/network/subnet>"
}
error
error downloading '<ssh://[email protected]/company/paas-multi-terraform-library.git>': /usr/bin/git exited with 128: Cloning into '/home/jenkins/agent/workspace/kinsfile-test_MSP-273-ci-jenkins/non-prod/amer/us-west1/mgmt/compute/dev_private_gke_cluster/.terragrunt-cache/h4cvKw_rhACL9f2Geh59b-KBmeI/6D1EtXnNY27AvhFueqKBaj4w-Gk'...
Warning: Permanently added the RSA host key for IP address '18.205.93.2' to the list of known hosts.
[email protected]: Permission denied (publickey).
data:image/s3,"s3://crabby-images/6ddbe/6ddbe14aa8f3190e4e4f2a16781590d3ed35fd6c" alt="jason einon avatar"
i have loaded the ssh key and other commands work, the key is also working locally
data:image/s3,"s3://crabby-images/6ddbe/6ddbe14aa8f3190e4e4f2a16781590d3ed35fd6c" alt="jason einon avatar"
jenkinsfile extract:
withCredentials([sshUserPrivateKey(credentialsId: 'company_bb', keyFileVariable: 'identity')]) {
sh ("eval `ssh-agent -s` && ssh-add ${identity} && ssh-add -L")
sh("ssh -T -oStrictHostKeyChecking=no [email protected] || true")
sh("cd non-prod/amer/us-west1/mgmt/compute/dev_private_gke_cluster/ && terragrunt apply --terragrunt-non-interactive --terragrunt-debug")
}
data:image/s3,"s3://crabby-images/6ddbe/6ddbe14aa8f3190e4e4f2a16781590d3ed35fd6c" alt="jason einon avatar"
any working examples or if anyone spots any glaring problems any support would be great
2020-09-09
data:image/s3,"s3://crabby-images/6ddbe/6ddbe14aa8f3190e4e4f2a16781590d3ed35fd6c" alt="jason einon avatar"
not pretty, but I have the required outcome using the below:
sh("eval `ssh-agent -s` && ssh-add ${identity} && cd non-prod/amer/us-west1/mgmt/compute/dev_private_gke_cluster/ && terragrunt apply --auto-approve --terragrunt-non-interactive")
data:image/s3,"s3://crabby-images/a4737/a473793029dabb7bbff0a643058746e30c672e9c" alt="Sam Holton avatar"
could format it like this as well:
sh """
command 1
command 2
command 3
etc
"""
data:image/s3,"s3://crabby-images/6ddbe/6ddbe14aa8f3190e4e4f2a16781590d3ed35fd6c" alt="jason einon avatar"
thanks @Sam Holton, I will be adding it to a shared library, plan to improve the formatting there
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Yeah, your initial sh() step was in a sub shell and then lost for subsequent calls. We’ve gotten around this with some git config and using PATs over HTTPS, so no ssh keys needed.
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
the plan-all/apply-all are very useful, but is there a way to only plan-some/apply-some with a list of modules to run?
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
Or, getting to my real use case, is there a way to run a module that has dependency
blocks on other modules while specifying --terragrunt-source
?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Don’t use ACTION-all commands IMO, they aren’t production safe. stdin/stdout all get munged, there is little way to control what exactly to target and the current implementation is broken if you want to save the plan to a planfile and pas that to your apply, which you should be doing.
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
fair enough
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
But is there a way to run a single module with input from dependencies against local source?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Not AFAIK. –terragrunt-source is used essentially for the terraform init -from-module
step for where to pull in the initial top level module, it won’t overrite your other sources in there to also point to local modules.
2020-09-11
data:image/s3,"s3://crabby-images/f45ee/f45eef3d6288e2ea0683bb6f37c32e4f596a2278" alt="Abel Luck avatar"
I’m attemping to use a dependency output in a locals block like so:
locals {
thing2 = do_stuff(dependency.another_module.outputs.thing)
}
dependency "another_module" {
config_path = "../another-module"
}
inputs = {
thing = local.thing2
}
But I’m getting the error :
[terragrunt] 2020/09/11 13:10:37 Not all locals could be evaluated:
[terragrunt] 2020/09/11 13:10:37 - thing2
[terragrunt] 2020/09/11 13:10:37 Could not evaluate all locals in block.
Can you not use dependencies in local blocks?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
because locals
are evaluated before dependency
blocks, you can not bind outputs from dependency
into locals
. On the other hand, for the same reason, you can use locals
in the dependency
blocks.
https://terragrunt.gruntwork.io/docs/getting-started/configuration/#configuration-parsing-order
Learn how to configure Terragrunt.
2020-09-14
data:image/s3,"s3://crabby-images/6da36/6da36d8e8390a18ac7befc852c167187bac27762" alt="ninja avatar"
hi, new to terragrunt. I am trying to set an env variable (AWS_PROFILE) as part of before_hook. I am trying this with the hope that the cmd is run in the same shell session as the terraform cmd will be run but now i think that’s not how the hooks work. Any suggestions on how i can have the AWS_PROFILE set for the terraform cmds automatically by terragrunt?
data:image/s3,"s3://crabby-images/a4737/a473793029dabb7bbff0a643058746e30c672e9c" alt="Sam Holton avatar"
Set it before hand in the terminal you are running terragrunt
data:image/s3,"s3://crabby-images/6da36/6da36d8e8390a18ac7befc852c167187bac27762" alt="ninja avatar"
@Sam Holton that’s what i am trying to avoid
data:image/s3,"s3://crabby-images/0e28a/0e28a0ab316a876deab5cdfca471a810d2bcaef7" alt="Joe Niland avatar"
Have you looked at using aws-vault?
You can use aws-vault exec
or mix it with the awscli credential_process option
2020-09-15
2020-09-17
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
i’m new to terragrunt and i’ve hit a snag that is difficult to solve since the online documentations is for the newester version. anyone still stuck on old versions of terragrunt in here?
i’m stuck on v0.18.7 and i wanted to read in another config file with read_terragrunt_config() but that seems to be a newer addition.
what i really want is to have a file somewhere in the parent folder path with a list of variables containing versions, that i can then reference in the terragrunt files like
terraform {
source = "[email protected]:org/module?ref=${version_from_var}"
...
}
any suggestions for workarounds or solutions that wil work with terragrunt 0.18?
Terragrunt allows you to use built-in functions anywhere in terragrunt.hcl
, just like Terraform.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@Mads Hvelplund Am using read_terragrunt_config()
for exactly this. Can you upgrade Terragrunt?
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
nope. i’m told by the ops guys that 0.18.7 is the last version that works with terraform 11
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Ah indeed, if you are TF 11 you are stuck.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Given TF 14 is alpha, may want to tackle that before a big infra refactor into Terragrunt
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
let’s just say that a government minister called out the project in the media for being late. now seems like the wrong time to upgrade everything
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
lol, what GOV? (used to work for GOV.UK)
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I’m assuming what you have works and Terragrunt was a refactor to DRY up the code a little?
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
terragrunt is a left over from when terraform 11 was cool. everything is actually being migrated to terraform 13, but there is a lot of code so it won’t happen overnight just because i’m too lazy to hard code 50 git tags
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
heh, sounds like stuck tbh
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
You could look at the read_terragrunt_config()
PR and re implement in a fork of 0.18 and use that?
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
that would be sprinkling parsley on a roadkill
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
data:image/s3,"s3://crabby-images/67e68/67e683361c271c4e26e156c64a1a2d27db2b053d" alt="David avatar"
Does the file with versions have any fancy HCL specific logic in it? If not, you could make that file JSON or YAML and then read in the file and decode it using older functions
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i’m pretty sure you can use the latest terragrunt, you just have to set terraform_version_constraint = ">= 0.11"
in your terragrunt config… https://terragrunt.gruntwork.io/docs/reference/config-blocks-and-attributes/#terraform_version_constraint
Learn about all the blocks and attributes supported in the terragrunt configuration file.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
we were doing that for quite a while, as part of our own upgrade path
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Ah, nice, I thought they’d done a hard cut off
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
they did, and then someone contributed the version_constraint argument, since there wasn’t really a technical reason for the restriction, more just a limitation of how they’re testing