#terraform (2019-09)
Discussions related to Terraform or Terraform Modules
Archive: https://archive.sweetops.com/terraform/
2019-09-02
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
Hi, I have been using the resource aws_ami_from_instance to create AMI. The problem with this approach is that I cannot delete instance after creating the AMI. The instance is useless after this. So basically my workflow is as follows:
- Create an Instance
- Run some script inside the instance
- Create an AMI from the instance
- Terminate the instance I have been recommended to use packer for this but problem with packer is that it is doesn’t have a good integration with Terraform (Also I’m passing a lot of variables in the scripts in step 2) Any suggestions please?
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
@jaykm FYI
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
@sahil I haven’t used packer but I am not sure why would you want to control packer with terraform.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
@Nikola Velkovski So the script I’m talking about in step 2 takes a lot of variables computed while running terraform. In case of aws_ami_from_instance, I can easily pass those variables inside the bash script, but same is not true for packer + terraform
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
hmmm you might want to drop terraform for that and maybe stick to aws cli
since blocking/maintaing a terraform state for baking amis doesn’t sound quite right.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
what kind of data you are computing with terraform? I am guessing ids/arns of resources ?
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
@Nikola Velkovski Yes, ids and arns.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
that is easily doable with aws cli
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
you are most probably using it for baking the ami, the dependency of terraform just makes it more complex.
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
I guess I’ll have to use aws cli instead. Thanks for your help.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
You are welcome, usually I do not use terraform for things that are contstantly changing, deploys etc.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
It gets cumbersome pretty quickly.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
How come you aren’t using Packer to bake AMIs?
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
—deleted because i’ve realized im stupid and can’t read —
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@sahil you can use terraform to setup codebuild with packer to setup your ami building pipeline.
After that you can use the aws_ami
datasource to get the last built ami.
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@sahil what about building a base AMI and passing in the Terraform computed variables as part of the user_data
script?
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
@davidvasandani Actually that might work. Thanks!
data:image/s3,"s3://crabby-images/ffcd6/ffcd62f2afe638cdec41a8e7d96ace8e9cb60532" alt="sahil avatar"
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@sahil No problem! Building a base AMI in Packer that can be used in both a staging and prod environment with different vars loaded at boot via Terraform make testing much easier! Keep us updated with your progress, if you run into any issues, or with a success!
data:image/s3,"s3://crabby-images/8d47e/8d47e333a63b342f2385e9ea8660bdfa54053df5" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Sep 11, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
2019-09-03
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I’m not sure if this is a TF12 problem or not, but I made another module just recently and this seemed to work, however - providers and their aliases are not found by the module anymore:
Error: Provider configuration not present
To work with
module.cicd-web.aws_iam_policy_attachment.cloudformation_policy_attachment its
original provider configuration at module.cicd-web.provider.aws.nonprod is
required, but it has been removed. This occurs when a provider configuration
is removed while objects created by that provider still exist in the state.
Re-add the provider configuration to destroy
module.cicd-web.aws_iam_policy_attachment.cloudformation_policy_attachment,
after which you can remove the provider configuration again.
I found this link: https://github.com/hashicorp/terraform/issues/21472 that states that providers need to be explicitly passed down to the module, which I tried but still doesnt work
Hi, I'm having problems upgrading to 0.12.0. We're running in eu-west-1 but one of my modules requires a cloudfront certificate that is only available in us-east-1. The main terraform file …
2019-09-04
data:image/s3,"s3://crabby-images/fcd46/fcd46a6e9dda9c565666cf7677513da05aeb77b0" alt="Matt avatar"
Cross posting this from r/terraform: https://old.reddit.com/r/Terraform/comments/czjnvq/analysis_paralysis_bootstrapping_a_new_terraform/ Anyone here have good examples for bootstrapping a clean parameterized Terraform deployment on AWS?
I’m working on a personal project and hitting a bit of a wall. I’ve been using Terraform for a while but other than a few tiny environments, I’ve…
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Matt is this your thread? If so #geodesic is a great tool that many of us will talk to you about
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It avoids Workspaces & wrappers like Terragrunt
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Rationale for “great tool” https://github.com/osulli/geodesic-getting-started/blob/master/docs/why-geodesic.md
data:image/s3,"s3://crabby-images/fcd46/fcd46a6e9dda9c565666cf7677513da05aeb77b0" alt="Matt avatar"
yes, that’s my thread @oscar
data:image/s3,"s3://crabby-images/fcd46/fcd46a6e9dda9c565666cf7677513da05aeb77b0" alt="Matt avatar"
I will take a look at Geodesic
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Matt tonight join https://zoom.us/meeting/register/dd2072a53834b30a7c24e00bf0acd2b8
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It is Sweetops weekly hour session
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Great chance to get a demo and ask Qs.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#office-hours starting in 15 minutes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#office-hours starting now! ask questions, get answers. free for everyone. https://zoom.us/j/508587304
data:image/s3,"s3://crabby-images/fcd46/fcd46a6e9dda9c565666cf7677513da05aeb77b0" alt="Matt avatar"
not sure I can make it @oscar, not this week
data:image/s3,"s3://crabby-images/fcd46/fcd46a6e9dda9c565666cf7677513da05aeb77b0" alt="Matt avatar"
but this is one of my major grips about Terraform which I generally like a lot
data:image/s3,"s3://crabby-images/fcd46/fcd46a6e9dda9c565666cf7677513da05aeb77b0" alt="Matt avatar"
otherwise
2019-09-05
data:image/s3,"s3://crabby-images/8856f/8856f3ef78b2f1b5e6d4a9a992f0efc9a360174a" alt="Tum avatar"
Sorry, for your modules, they compatible with Terraform version 0.12+?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not all of them are converted to 0.12 yet (we are working on it)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
those that were converted have hcl2
label https://github.com/cloudposse?utf8=%E2%9C%93&q=hcl2&type=&language=
data:image/s3,"s3://crabby-images/8856f/8856f3ef78b2f1b5e6d4a9a992f0efc9a360174a" alt="Tum avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can thanks. We also adding Codefresh instead of Travis, and adding tests which are deployed to AWS using Codefresh pipelines (this complicates the task for you)
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
https://github.com/terraform-providers/terraform-provider-aws/issues/9995
Add your thumbs up if that would be useful to you.
Community Note Please vote on this issue by adding a reaction to the original issue to help the community and maintainers prioritize this request Please do not leave "+1" or "me to…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Community Note Please vote on this issue by adding a reaction to the original issue to help the community and maintainers prioritize this request Please do not leave "+1" or "me to…
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
being quite busy the past few weeks (going back to fixing terraform-lsp on the weekend) was working on a nice research and production project
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
the project being openstack on nomad
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
Now I’m just curious was CloudKitty
is
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
Billing and Chargeback service of OpenStack
2019-09-06
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Hey guys, I am looking for a way to have my AWS autoscaling group perform a shutdown script before scaling down. The only way I can find to do this is using lifecycle hooks > Cloudwatch Events > lambda > SSM . But this seems quite a chain to string together. Any suggestions?
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
the life cycle hook is probably the way to go, but you could try https://opensource.com/life/16/11/running-commands-shutdown-linux as well
Linux and Unix systems have long made it pretty easy to run a command on boot. But as it turns out, running a command on shutdown is a little more complicated.
data:image/s3,"s3://crabby-images/dd5db/dd5dba6a9c7687fc82a7994fe9cec50246f69444" alt="Jonathan Le avatar"
i’m not sure what your use case is and how important it is to get the shutdown script to run appropriately OR if you OS is event linux.
unless the OS goes bad, the scale in in an ASG will try to let the instance shutdown gracefully - this would let units in /usr/lib/systemd/system-shutdown/ run. i’m not sure what the timeouts would be before a forceful termination by the ASG.
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
K99runmycommandatshutdown
from the link above works really well in both ASG’s and SpotFleet instances.
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Thanks!
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
I will give it a crack and see if this is for for purpose as it has a lot less moving parts. Thanks for the assistance @Jonathan Le @davidvasandani.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
imho that’s the only way
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
it is normally used for ecs/ecs2 connection draining on scale in(down)
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
but in your case it might be even more complex since the script has to report success
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Thanks @Nikola Velkovski
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
you are welcome
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
was hoping someone with regex expertise can help me out here, Im trying the following:
${replace(var.project, "/\\s$/", "")}
where var.project
is a string that will end in the letter s
. I’m trying to strip the s
at the end but im not having any luck. When I run this the s
remains. Any ideas?
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
You need to use $1
as described here - https://nedinthecloud.com/2018/08/27/terraform-fotd-replace/
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
@Brij S Your regex is replacing \s, not s
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Try ${replace(var.project, "/s$/", "")}
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
The other approach, to @antonbabenko point, is to match the whole string: ${replace(var.project, "/^(.*)s$/", "$1")}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or just use substr("str", 0, length("str") - 1)
without messing up with regex (https://blog.codinghorror.com/regular-expressions-now-you-have-two-problems/)
2019-09-09
data:image/s3,"s3://crabby-images/8648b/8648b3ff12f83027957065a6137e327b8b97f21c" alt="Michał Czeraszkiewicz avatar"
Hi, How can I reference resources created with for_each
?
Below the example what I try to accomplish:
locals {
users = ["user1", "user2"]
}
resource "aws_iam_user" "this" {
for_each = toset(local.users)
name = "${each.value}"
}
resource "aws_iam_access_key" "this" {
for_each = toset(local.users)
user = # Reference above created users
}
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hi @Michał Czeraszkiewicz
user = aws_iam_user.this[each.key].name
data:image/s3,"s3://crabby-images/8648b/8648b3ff12f83027957065a6137e327b8b97f21c" alt="Michał Czeraszkiewicz avatar"
@maarten thx
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
Hello
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
is terragrunt considered a “best practice” tool to be using?
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
I don’t know if I consider it a “best practice” tool… most of the must have features of terragrunt (i.e. state locking during apply) have made it to terraform, my answer would be different if this was asked a year or so ago
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
just asking because i previously worked in a place that we had one terraform repo per environment(dev,prod,staging)
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
and we had to do alot of repeatable work in each env
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
It could be used for a very specific style of writing TF to keep things DRY, though you can do this now with workspaces, as well… I’m a fan of this workflow: https://github.com/cochransj/tf_dynamic_environment_regions
This repository is an example of how to use terraform workspaces to implement the same resource declarations across multiple aws accounts across multiple regions. It also shows how to have a data d…
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Note: a lot of that assumes you are using TF 0.12+
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
thanks
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
another question
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
imagine that i have an RDS instance in prod
env, but i do not have it in dev
env
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
i would be able to accomplish this with terragrunt or workspaces?
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
sure
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
conditional statement on count which i believe is possible in 0.12, psuedo code: IF $terraform.workspace == “prod” THEN count = 1 ELSE count = 0 on the RDS resource
data:image/s3,"s3://crabby-images/a1f9e/a1f9e81decf220a56c64df5037465cf0a8b9f857" alt="Fernando Torresan avatar"
When we talking about multple accounts, teams, environments…for me, terragrunt has been totally necessary to keep my terraform code organized and without so much boilerplate code
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
thx
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
one last question
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
i used to work with 1 big tfstate per environment
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
is a best approach to be using multiple tfstates per resourcegroup?
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
so we can manage VPCs individually, EC2s individually, etc….
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
we like to split tfstate on multiple dimensions… such as team and stage and app and stateful/stateless…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
though, “individually” is a bit relative… for many actions, you can use -target
to restrict the scope of an action… splitting tfstate helps reduce the blast radius of accidents better IMO though
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
nice
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
also see the recent thread/posts by @Erik Osterman (Cloud Posse) in #geodesic for another approach… https://sweetops.slack.com/archives/CB84E9V54/p1567187759027700
but this also is freggin scary. i think it’s optimizing for the wrong use-case where you start from scratch. i think it’s better to optimize for day to day operations and stability.
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
each team has autonomy to apply
without interfering in other team infrastructure
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
basically, i just started in a new company, nothing in IAC yet
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
and i’m researching good strategies/architectures to start our environments
data:image/s3,"s3://crabby-images/8ac83/8ac8380fd9dd362ec78f9117c836614f78b5e9dd" alt="Marcio Rodrigues avatar"
and i’m thinking about splitting into multiple tfstates, because we have a project to make a disaster recovery plan. We should be able to disaster recover only some portions of our infrastructure, into another region
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
we use terragrunt because it is visual (hierarchy/tfstate by directory structure) and easy to comprehend. tf workspaces are less visible in that sense and IMO harder to “know” where you are working. geodesic is solving similar problems in another way entirely
data:image/s3,"s3://crabby-images/004c6/004c63b2ee6db0afba1d838c774a94adb216bb2e" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Sep 18, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
does anyone know how to get the function name of a created lambda?
resource "aws_lambda_function" "s3_metadata"
, can this resource be accessed via aws_lambda_fuction.s3_metadata.id
?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
the docs dont make it apparent..
data:image/s3,"s3://crabby-images/9df9d/9df9d6b09266444cf9c709dc2163eb0cd2282019" alt="aaratn avatar"
aws_lambda_fuction.s3_metadata.function_name
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
since tomorrow is HashiConf
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
is that a prediction or a question
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
I am giving my prediction that maybe they will officially announce packer 2.0 with HCL2?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
how can i pass db_subnet_group_name
to aws_rds_cluster
resource using data object ?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
currently i am trying to use
db_subnet_group_name = "${element(data.my_state.networking.database_subnets,1)}"
2019-09-10
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
does anyone know how to read subnet name from state file ?
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@rohit doesn’t look like there is a data source for this yet: https://github.com/terraform-providers/terraform-provider-aws/pull/9525
Adds a data source for aws_db_subnet_group. Used aws_db_instance as a model for this work. Currently only allows looking up exactly one database subnet group using name as the argument, although th…
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
@sarkis thanks. I will try a different alternative then
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
data:image/s3,"s3://crabby-images/43d3c/43d3c1c75f44b29a42d3a05c54c06d40b8e53a9e" alt="attachment image"
Join us live as HashiCorp Founders Armon Dadgar and Mitchell Hashimoto deliver the opening keynote at HashiConf in Seattle, WA.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
terraform plan getting a cost estimation feature on TF Cloud interesting…
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
I didn’t find any references to ECS Service Discovery in CP modules. Is it because everyone is running an alternative solution?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
For someone getting started with containers, and not having more than 3-4 services at the most, should I even bother with orchestration and/or sophisticated methods of service discovery?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Or will ALB/ECS combo get the job done?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for that we usually deploy https://istio.io/docs/concepts/what-is-istio/ in the k8s cluster
Introduces Istio, the problems it solves, its high-level architecture and design goals.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
don’t have anything in TF
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Introduces Istio, the problems it solves, its high-level architecture and design goals.
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
That’s what AWS AppMesh does, right? I wonder if that’s an overkill for my use case though.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes AppMesh should do similar things. we did not use it yet
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for 3 static services might be an overkill but at the same time, you get an experience and be able to use it with tens of services
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Has anyone played with the new Terraform SaaS offering?
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Looks like TF cloud has hit GA
2019-09-11
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Not yet but took a read. Keen to hear someone’s experience & comparison to local Geodesic workflow / CI tools using Geodesic workflow / Atlantis
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
definitely +1 on this. This is the workflow that we’ve just committed to, so keen on hearing peoples experiences!
data:image/s3,"s3://crabby-images/a8c7b/a8c7b654eebf315d51a4eb9294e0be7184d6e59a" alt="Haydar Ciftci avatar"
I have a hard time getting the cloudposse modules to work with the recent terraform version (v0.12.8). I feel like I’m missing something, any ideas?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make sure all modules you are using are converted to TF 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
For example, this one is now cloudposse/terraform-aws-alb
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Don’t know about all modules in terraform-aws-modules/.......
(they are CloudPosse’s)
data:image/s3,"s3://crabby-images/a8c7b/a8c7b654eebf315d51a4eb9294e0be7184d6e59a" alt="Haydar Ciftci avatar"
Yeah, so it is indeed an issue with the module implementation itself?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not implementation
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the modules that are still in TF 0.11 syntax will not work in TF 0.12 (with a few small exceptions)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Try:
on .terraform/modules/alb_magento2/main.tf line 33, in resource "aws_security_group_rule" "http_ingress":
33: cidr_blocks = [var.http_ingress_cidr_blocks]
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Change: removal of "${
and }"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
If that doesn’t work, try:
cidr_blocks = var.http_ingress_cidr_blocks
.. since it is already a list
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#office-hours starting now! ask questions, get answers. free for everyone. https://zoom.us/j/508587304
2019-09-12
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
How are folks doing multi region as far as Terraform goes…?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
provider per region, pass the provider explicitly to each module/resource
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
these guys have the best reference i’ve seen for it, https://github.com/nozaq/terraform-aws-secure-baseline/blob/master/providers.tf
Terraform module to set up your AWS account with the secure baseline configuration based on CIS Amazon Web Services Foundations. - nozaq/terraform-aws-secure-baseline
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Workspaces ?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I’m more interested in things like what you do with the state file
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
is it the age-old question of one giant state, or many smaller states? i think either way it would be controlled by the backend config…
you can have a backend config with a credential that keeps it all in one region if it is one state, should work fine, even if the resources are in multiple regions
or a backend config per state where you apply some rationale/logic to where you want that state stored…
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I don’t think this is so simple. You can’t have state for multi regions all in a bucket in one of the regions
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
the region goes down, which maybe the reason you have gone multi region in the first place, now you can’t get to your TF state
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
why not?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
that’s a different issue, not a technical limitation of tf
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I wasn’t talking specifically about restrictions by TF, I’m wondering how people are doing it in a sane way
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
re a conversation I’ve just had with @Nikola Velkovski
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
would cross-region bucket replication be sufficient?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
set that up on your backend, then repoint your backend config in tf if you need to use another region
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Yeah that could get you out of a bit of a hole, but I don’t want to have to repoint backends etc
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
what is your backend? can you do consul or something in a cross-region way?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
S3
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
This is what I found regarding remote state and workspaces
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Terraform can store the state and run operations remotely, making it easier to version and work with in a team.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
sorry here it is for s3
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Terraform can store state remotely in S3 and lock that state with DynamoDB.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
hmm no mention of changing the bucket with workspaces
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
IIRC you can’t use interpolation in the backend block
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
with s3, to avoid manually re-jiggering your backend, you would need to be managing the s3 endpoint rather explicitly, doing some kind of health check on the real endpoints and re-pointing things as necessary
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
and you may still hit problems when running tf, since you’d have to also be quite careful about targeting resources to avoid running against the downed region
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I haven’t yet seen a setup that actually addresses these problems. setting up multiple providers in the same state feels like half a solution, and one that will likely bite you when you need to reach for it
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
It isn’t easy
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
yeah, if this is that big a concern, you may be best off confining a state to a single region as much as possible, and setting up your app accordingly (deploy independently to multiple regions)
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
still may need some coordination layer perhaps that your app states depend on, but now your cross-region blast radius is confined to just that resource
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
which goes into a state bucket for each said region
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
replicate between each other maybe
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
using one bucket, different paths of state per regions you can do that manually means having below tree:
providers/aws
├── eu-east-1
│ ├── dev
│ ├── pre
│ ├── pro
│ └── qa
└── eu-west-1
├── dev
├── pre
├── pro
└── qa
or you can use terraform workspaces
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
terraform workspaces can’t be interpolated into backend config AFAICR
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I think one bucket isn’t ideal…
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
for me one bucket seems ideal, and you can only play with paths inside it.
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
and if eu-west-1 goes down? you can’t provision in eu-west-1 OR other region ?
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
s3 is a global service
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
buckets are regional, have def seen S3 in a region go down before (not often but has happened and one of the drivers for going multi region for me)
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
Ah my bad S3 bucket name is unique globally, confused totally agree with you on that spin up a bucket for each region is ideal
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@joshmyers would Aurora Serverless Postgres as a TF backend solve this problem?
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
I believe that if a region went down the DNS would just failover to the new promoted master in a new region.
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
or leveraging Minio distributed across multiple regions (or even cloud providers!) https://dickingwithdocker.com/2019/02/terraform-s3-remote-state-with-minio-and-docker/
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Thanks @davidvasandani, will have a look!
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Let us know what you end up going with? I know at some point I’ll need to address a more robust TF backend.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
continuing the thread in order to go multi region/environment we can do something like this
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
locals {
environment = element(split("_", terraform.workspace), 1)
region = element(split("_", terraform.workspace), 0)
}
output "region" {
value = local.region
}
output "environment" {
value = local.environment
}
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
and the the workspace should be set like
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
eu-west-1_staging
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
it’s a bit hacky but does the trick
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
backends don’t allow interpolation, so you are gonna need some kind of wrapper to get different buckets per region without inputting vars etc
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
yes it also doesn’t tackle the state problem
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
but it sounds like you don’t want to put your state in an s3 bucket
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
maybe other backends might work for you ?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
No I think S3 is fine, but it needs to be regional specific and therefore named buckets, so need some way to easily toggle the backend bucket too
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
The Aurora Postgres idea is interesting, but a few things. Requires much more setup, automating that is possible, but a pain. Requires credentials. Doesn’t solve one of the problems we spoke about. State would be all good in the case of a regional failure as DNS should flip over to the other region and should be all good, but if you have multi region provider in a single run anyway, you are gonna have a hard time if one of those regions is down
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Half of your apply or so is gonna fail, potentially leaving you in an interesting state
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Really good point.
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Have you thought of ways to simulate this?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Nope, and my guess is that when AWS breaks in such a way, all bets are off anyway, but moving onto a client where this is a major concern and wanted to know others feelings
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@Erik Osterman (Cloud Posse) any thoughts?
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
I believe the plan is to usually decouple the infrastructure and application so that the application self heals until the provider resolves the outage (ie don’t try to terraform while S3 is offline )
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
but looking to hear Erik’s thoughts on this.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
terragrunt is a wrapper that lets you use some interpolation in the backend config, it resolves it and constructs the init command for you
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
heh, I know, that is about all I want out of it at this point! lol
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
+1 for #terragrunt
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Mike Whiting can you share how you are invoking the module?
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
@Mike Whiting has joined the channel
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
@Nikola Velkovski yep that’s the one
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
oh that woiuld be me
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
what a coincidence
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
are you using terraform 0.12 by any chance ?
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
yeah
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
unfortunately it has not been ported yet
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
but I can dedicate some time and do it
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
that would be awesome
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
cool
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
just to clarify…
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
this will enable ec2 instances to log to cloudwatch events
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
what do you mean by cloudwatch events
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Cloudwatch events are cron like jobs
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
ah ok
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
it will add additional metrics to cloudwatch
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
I just want to see logs from docker
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
ah that’s not it.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
in order to see the logs
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
from docker you’‘ll need to have:
- the dockerized app to write to stdout
- iam role for the ec2 machines to write to cloudwatch logs
- a log group in cloudwatch logs
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I think that should do it
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
sounds good…
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
however let me explain how I got here
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
oh and this
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
You can configure the containers in your tasks to send log information to CloudWatch Logs. This allows you to view the logs from the containers in your Fargate tasks. This topic helps you get started using the awslogs log driver in your task definitions.
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
I’m creating a aws_ecs_task_definition and I suspect the service is failing to start because the docker image resides on a gitlab image registry and I imagine it’s not possible to use a docker image somewhere where the authentication isn’t through AWS
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
but I was hoping to see evidence of that through some kind of logging
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
if it’s ECS/EC2 then you can ssh into the machine and check the agent logs
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
otherwise you’ll need to set up logging
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
from experience the most usual problem is that the instances do not have internet
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
you can try with a simple docker image
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
e.g. nginx
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
and see if it works
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
if I use a vanilla docker image e.e. jenkins:lts which is available publically then everything works
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
*e.g
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
so it’s not an internet issue
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
you should see how to authenticate through docker with gitlab
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
makes sense.. I suppose actually I just need to perform the authentication through the user_data field of aws_launch_configuration
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
pretty much
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
thanks.. that’s given me some direction
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
@Erik Osterman (Cloud Posse) what’s the workflow in this case, should Mike create an issue ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ya if he needs it now, the best bet is to fork and run terraform upgrade
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
cool thanks
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
hey guys i am trying to create a ec2 (after taint’ing the existing ec2), attaching the ebs volume(using aws_volume_attachment), and using an user-data script in my tf to mount the volume (which is /home), and also trying to import some data from /home to the newly created instance, problem is many times the /home is not mounted, and the /var/log/cloud-init-output.log
shows No such file or directory
to the files i am trying to import, any thoughts on this ?
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
^ hope that question is not confusing
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
problem is many times the /home is not mounted
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
is it never mounted, or just sometimes fails?
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
well most of the times it is never mounted(9/10 times) , i manually ssh into the instance and do a sudo mount -a
and it mounts, i tried adding sudo mount -a
to the user-data script itself – doesn’t help
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
might be some race conditions
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
e.g. something (EBS) is not ready yet, but the code tries to mount it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
try to add a delay for testing
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or maybe there are some settings to wait
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
i tried adding sleep 60
in the user-data script which didn’t work, OR should i add something to the terraform itself for the wait
thingee ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no, tf does not wait for ramdom things, just for resources to be created (and not for all in all cases)
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
oh got it, will try some combinations of wait
in my user-data script itself
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I have a bash script which has a line cd /run/media/Username/121C-E137/ this script is triggered as soon as the pen-drive is recognized by the CPU but this line should be executed only after the mo…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I am using mount -o bind /some/directory/here /foo/bar I want to check /foo/bar though with a bash script, and see if its been mounted? If not, then call the above mount command, else do somethin…
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
still trying ways mentioned from ^ stackoverflows, came up with
if sudo blkid | grep /dev/xvdb > /dev/null; then
sudo mount -a
else
sleep 10
fi
any elegant approaches to make that in a loop ?
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
update: right now adding a direct sleep 10
(without any loop) seems to have solved the problem
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
hey all, all of a sudden i’m getting this error when running terraform apply
Error: error validating provider credentials: error calling sts:GetCallerIdentity: NoCredentialProviders: no valid providers in chain. Deprecated.
I have no idea why this is happening. The only thing I did was add some credentials to my .aws/credentials
file.
My providers look like this
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "storesnonprod"
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "storesprod"
alias = "prod"
}
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
does anyone know what might be causing this?
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@Brij S is it possible you mucked up your .aws/credentials toml format so it’s not being parsed correctly by the TF provider?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@sarkis, it seems when I add some old profiles back to the credentials file it works. But when I remove them i get the error
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
do your profiles depend on each other? i think there was something like source_profile i can’t remember the exact param
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
no
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
two seperate profiles as you see in the snippet above
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
can you share your ~/.aws/credentials file in DM and redact sensitive data
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
sure
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Anyone using a tool like drifter
or terraform-monitor-lambda
to detect state drift?
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Any success or best practices for identifying and correcting Terraform changes over time?
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Check for drift between Terraform definitions and deployed state. - digirati-labs/drifter
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Monitors a Terraform repository and reports on configuration drift: changes that are in the repo, but not in the deployed infra, or vice versa. Hooks up to dashboards and alerts via CloudWatch or I…
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
While these can be useful in a small environment, they are supporting a problematic process and are not going to scale well
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
If using micro services, there will be a state file per microservice. Lets say you a small environment with only 10 service and you have 3 environments. That’s 30 state files plus a few more for environment infrastructure and a few for account infrastructure. This can grow fast
data:image/s3,"s3://crabby-images/17ee2/17ee2a9c1147340bd90d17feda227e33c1d2f185" alt="Steven avatar"
Then there is the bad process that it is supporting. People making production changes from their local systems with possibly no testing or any audit tracking. A much better process would be to commit the change to git repo and have that trigger the terraform run. This gets rid of the drift issue due to uncommitted changed. It also allows you to add testing and ensure it is run, as well as having an audit trail
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
master brach reflects what is deployed to prod. With all the history from the PRs. There should be no drift since what’s is currently in master is deployed to prod with terraform/helm/helmfile
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what we usually do to make and deploy a change to apps in k8s and serverless: create a new branch, make changes, open a PR, automatically (CI/CD) deploy the PR to unlimited staging so people could test it, approve the PR, merge the PR to master, cut a release which gets automatically deployed to staging or prod depending on release tag
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for infrastructure (using terraform): create new branch, open a PR, make changes, run terraform plan
automatically, review the plan, approve the PR, run terraform apply
, if everything is OK, merge the PR to master
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we use atlantis
for that
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
2019-09-13
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
@Brij S you can verify if the profiles are properly set with aws cli
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
e.g. aws s3 ls --profile storesnonprod
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
because terraform uses that
data:image/s3,"s3://crabby-images/71c53/71c5354edb56c50288ba920e77e4a43c32782973" alt="Maciek Strömich avatar"
or by
AWS_PROFILE=profilename aws s3 ls
data:image/s3,"s3://crabby-images/d2dcf/d2dcfacd6b731bfc0f85081aafea45f2bfd433ba" alt="ciastek avatar"
I need something like “random_string” resource, but with a custom command. So, execute a command only if the resource isn’t in the state yet (or was tainted), and use commands output as a value to put in the state. Any idea what kind of magic to use to achieve such result?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
something like here https://github.com/cloudposse/terraform-root-modules/blob/master/aws/grafana-backing-services/aurora-mysql.tf#L118
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you provide the param in var, use it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if not, use random string to generate it
data:image/s3,"s3://crabby-images/d2dcf/d2dcfacd6b731bfc0f85081aafea45f2bfd433ba" alt="ciastek avatar"
Thank you. Unfortunately it’s not the thing I look for. I need something like:
resource "somemagicresource" "pass" {
command = "openssl rand -base64 12"
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
The local-exec
provisioner invokes a local executable after a resource is created. This invokes a process on the machine running Terraform, not on the resource. See the remote-exec
provisioner to run commands on the resource.
data:image/s3,"s3://crabby-images/d2dcf/d2dcfacd6b731bfc0f85081aafea45f2bfd433ba" alt="ciastek avatar"
Unfortunatelly provisioners doesn’t store any kind of result in a state.
data:image/s3,"s3://crabby-images/d2dcf/d2dcfacd6b731bfc0f85081aafea45f2bfd433ba" alt="ciastek avatar"
I’ll try to go with https://github.com/matti/terraform-shell-resource , but thanks for all the links provided
Contribute to matti/terraform-shell-resource development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Have you guys seen this before?
Error: Error creating S3 bucket: BucketAlreadyOwnedByYou: Your previous request to create the named bucket succeeded and you already own it.
status code: 409, request id: aaaa, host id: aaaa//bbbb+cxxx=
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It doesn’t exist on ANY of our accounts
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
its a very, very, specific and niche bucket name
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
the changes someone else owns it is extremely slim
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’m sure I saw this about 4-5 months ago, but it actually was created on one of our accounts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we saw that happens when you create a resource (e.g. bucket) not using the TF remote state. Then the state was lost on local machine. Then TF tries to create it again, but it does exist in AWS
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
check that you use remote state and not losing it
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yeh that adds up with what potentially happened
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
That local state file is long gone
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
How can I recover the S3 bucket? :S
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to find it in AWS
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and either destroy it manually in the console, or import it
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It isn’t there
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’ve searched hte account (it has no buckets) - new account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make sure you have permissions to see it (maybe it was created under diff permissions)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yeh I’ve checked sadly with Admin permissions in console
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It genuinely isn’t there, even got one of the IT guys to look
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’ve opened a ticket with AWS but slow
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
S3 is global, so you need to check all your accounts, even those you don’t know about
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Wait so, it could be on a different aws account to that on which I ran terraform?!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it could be. I don’t remember if AWS shows the error Error creating S3 bucket: BucketAlreadyOwnedByYou: Your previous request to create the named bucket succeeded and you already own it
in this case
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
AWS console just shows name already in use
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
when attempting to replicate but in the console
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
aghhh
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so yes, you created it before and lost the state (if you are saying that the chance is very slim that some other people used the same name)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
But surely even if I lost the state file
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
the s3 bucket would be on the aws account
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
btw the context is the backend module
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Weird it has happened again on another account
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
it is in my local state file
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
a resource
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but it isn’t on the console
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
what is going on
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you have to follow exact steps when provisioning the TF state backend because you don’t have the remote backend yet to store the state in
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yeh no I know
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
it was an accident
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’m familiar with it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you have to provision it first with local state, then update TF code to use remote S3 backend, then import the state
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Probably the 18th account I’ve used your module on.. just something weird happened this time
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Ya, I do this:
run:
# Apply Backend module using local State file
direnv allow
bash toggle-s3.sh local
terraform init && terraform apply
# Switch to S3 State storage
bash toggle-s3.sh s3
terraform init && terraform apply
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
and my toggle-s3.sh script basically comments out hte backend
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It’s worked plenty time
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
not sure what happened this time though
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i guess the bucket with that name exists for any reason (you created it, other people created it on diff account, or other people from diff orgs created it). Try to use a diff name
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
No I think something weird is happening
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
on a second account I’m getting this
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Error: Error in function call
on .terraform/modules/terraform_state_backend/main.tf line 193, in data "template_file" "terraform_backend_config":
193: coalescelist(
194:
195:
196:
|----------------
| aws_dynamodb_table.with_server_side_encryption is empty tuple
| aws_dynamodb_table.without_server_side_encryption is empty tuple
Call to function "coalescelist" failed: no non-null arguments.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’ve followed the same pattern and commands as many accounts previously
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
all version locked etc
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
No clue why it isn’t having it today
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
annnnnd its working again
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
what the ?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
what theee
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
that magic bucket thats there but not there?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
can see it on aws cli
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but not console
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
whaat
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
same permissions (iam role)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@oscar I think you mixed up TF versions
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you use 0.11, use 0.11 state backend
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
same for 0.12
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Its aws
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
look at htis
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
✗ . (none) state_storage ⨠ aws s3 rm <s3://xxx-terraform-state>
-> Run 'init-terraform' to use this project
⧉ xxx
✗ . (none) state_storage ⨠ aws s3 ls
2019-09-13 14:20:17 xxx-terraform-state
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
even after removing it is stil there hahaaha jeez
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or, another posibility, aws provider was not pinned, got updated, and the new one has issues
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we had a few 0.11 modules basted after the aws provider was updated
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I think you nailed it akynsh#
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
andriy*
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
managed torecover the state file by cli#
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Error: Failed to load state: Terraform 0.12.6 does not support state version 4, please update.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
that was released just this morning
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I wonder if I had the .terraform/modules directory already there
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so the conclusion is, always pin everything, TF modules, TF version, providers, etc.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Damn I have it pinned to major
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
aws = “~> 2.24”
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so I found out why my module was using different credentials. It was because i had a [main.tf](http://main.tf)
in my module with the following content:
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "ambassadorsnonprod"
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "ambassadorsprod"
alias = "prod"
}
However, when I remove this [main.tf](http://main.tf)
file from the module, and run tf plan
with configuration that references this module I get the following error:
To work with
module.cicd-web.aws_iam_policy_attachment.cloudformation_policy_attachment its
original provider configuration at module.cicd-web.provider.aws.nonprod is
required, but it has been removed. This occurs when a provider configuration
is removed while objects created by that provider still exist in the state.
Re-add the provider configuration to destroy
module.cicd-web.aws_iam_policy_attachment.cloudformation_policy_attachment,
after which you can remove the provider configuration again.
I have a main.tf that is setup so I’m not sure why im getting this error
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
ominously similar to my situ
data:image/s3,"s3://crabby-images/3abc9/3abc9c5ff2c4a1fe015edddd578a1b308df03005" alt="Todd Linnertz avatar"
I am looking at using the SweetOps s3_bucket module but I am not sure how to enable server access logging using the module. Does the module support enabling server access logging?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
depending on the s3 module you want to use
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this one supports it https://github.com/cloudposse/terraform-aws-s3-website/blob/master/main.tf#L48
Terraform Module for Creating S3 backed Websites and Route53 DNS - cloudposse/terraform-aws-s3-website
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m having some issues with Terraform and terraform-aws-rds-cluster module, I’m creating a Global cluster ( I forked the cloudposse module and added one line) but this is not just related to to global aurora clusters but the problem is that the cluster finish creating but terraform for some reason keeps pooling for status until it times out after 1 hour , this is what I see :
module.datamart_secondary_cluster.aws_rds_cluster.default[0]: Creation complete after 9m10s [id=example-stage-pepe1secondary]
module.datamart_secondary_cluster.aws_rds_cluster_instance.default[1]: Creating...
module.datamart_secondary_cluster.aws_rds_cluster_instance.default[0]: Creating...
module.datamart_secondary_cluster.aws_rds_cluster_instance.default[0]: Still creating... [10s elapsed]
module.datamart_secondary_cluster.aws_rds_cluster_instance.default[1]: Still creating... [10s elapsed]
module.datamart_secondary_cluster.aws_rds_cluster_instance.default[1]: Still creating... [20s elapsed]
module.datamart_secondary_cluster.aws_rds_cluster_instance.default[0]: Still creating... [20s elapsed]
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that will continue for 1 hour…..
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and the console will show it as available
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you see that eveytime you provision or just saw one time?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
have you seen this before ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if it only once, I’d say your session had expired
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it is pretty consistant
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the workaround was to create the secondary cluster with 0 instances
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
then change it two instances
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
pretty much every time
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I mean I have not been able to successfully complete the creation the cluster
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
has anyone used multiple providers for a module?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Ive done this multiple times with success, but now I’m facing an issue where all resources are created in one account(provider) and not the other and i’m not sure why
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@Brij S you’ll need to post some code or errors for us to help you diagnose.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I had an issue like that yesterday, the name of the resource needs to be different and you need to pass the provider alias to every resource
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
in my /terraform/modules/cicd
folder Ive got a [main.tf](http://main.tf)
file with the following:
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
alias = "prod"
}
in my /terraform/cicd/stores
folder Ive got a [main.tf](http://main.tf)
with the following:
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "storesnonprod"
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "storesprod"
alias = "prod"
}
and ive got a /terraform/cicd/stores/web.tf
file Ive got
module "cicd-web" {
source = "../../modules/cicd-web"
providers = {
aws.nonprod = "aws.nonprod"
aws.prod = "aws.prod"
}
........
in all of my resources ive got either a provider = "aws.nonprod"
or provider = "aws.prod"
but they all get created in aws.nonprod
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@davidvasandani ^
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
However, I realized that if I put profiles in /terraform/modules/cicd/main/tf
then it works! However, that defeats my purpose of the module since id want to use different profiles for different accounts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
there is no difference between these providers
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
alias = "prod"
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they are the same
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
thats a good point.. didnt notice that
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they need to have some diff, e.g. region
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
but the region is the same as well
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
if i remove that main.tf from the module I get an error saying it needs it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they have to be diff otherwise why do you need them
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
provider "aws" {
region = "us-west-2"
shared_credentials_file = "/Users/tf_user/.aws/creds"
profile = "customprofile"
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
diff region, or diff profile, or diff shared_credentials_file
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
right, I can add profile but if that lives in the module I cant reuse it
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
for another set of accounts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which tells the provider to use diff credentials from diff profile to access diff account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to add that
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
if I leave profile
in the [main.tf](http://main.tf)
in the module, then I cant reuse the module
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
because another account will have a different profile
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
whatever you are saying you can’t reuse, does not make any diff for terraform
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so in my module, ``/terraform/modules/somemodule` i have a main.tf which includes a profile which is used for account A
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you create a set of providers (they should differ by region or profile)
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
differ by profile, yes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then for each module, you send a set of required providers
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and in each resource use the provider aliases
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
there is no other way of doing it
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
wait, in the module, the main.tf if I put a profile in
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
how does the module become reusable if the profile is hardcoded for a certain account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the module is reusable because you send it a list of providers (which can contain only one)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and the module uses that provider
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
w/o knowing the provider details
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Modules allow multiple resources to be grouped together and encapsulated.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yes I understand that
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so that means, I remove [main.tf](http://main.tf)
from my module?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
(which causes errors)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not sure I understand that
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
ok let me explain
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you fix the error in main.tf
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not remove it
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
in /terraform/modules/somemodule/main.tf
I have:
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
alias = "prod"
}
In /terraform/folder/main.tf
I have:
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "storesnonprod"
alias = "nonprod"
}
provider "aws" {
version = "~> 2.25.0"
region = var.aws_region
profile = "storesprod"
alias = "prod"
}
In /terraform/folder/web.tf
I have:
module "cicd-web" {
source = "../../modules/somemodule"
providers = {
aws.nonprod = "aws.nonprod"
aws.prod = "aws.prod"
}
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
that is how im using the providers
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
can you have multiple providers in a module ?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you can. kinda need to when you want to implement a cross-account workflow, for things like vpc peering, resource shares, etc…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I think you can but should you do it ?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
if I remove /terraform/somemodule/main.tf
I get this error:
Error: Provider configuration not present
To work with
module.somemodule.aws_iam_policy_attachment.codepipeline_policy_attachment its
original provider configuration at module.somemodule.provider.aws.nonprod is
required, but it has been removed. This occurs when a provider configuration
is removed while objects created by that provider still exist in the state.
Re-add the provider configuration to destroy
module.somemodule.aws_iam_policy_attachment.codepipeline_policy_attachment,
after which you can remove the provider configuration again.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
in my case I instantiate the module twice one with one provider and one with the other
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
look at this example
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
they don’t create one resource within two providers
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
in my module I have multiple resources that have either provider = "aws.nonprod"
or provider = "aws.prod"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmm, maybe moving to a module that can do do any provider and the pass one provider to the module
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok, we are mixing up at least 4-5 diff concepts here
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
sorry
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- @Brij S if you created resources using a provider, you can’t just remove it. Delete the resources, then remove the providers from
[main.tf](http://main.tf)
, then re-apply again
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- @Brij S your providers must be different (that’s after you do #1). Otherwise TF uses just the first one since they are the same (that’s why eveything gots created in just one account)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- @jose.amengual you create a module, but don’t hardcode any provider in it. You can send the provider(s) to it IF nessessary
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- But in (almost) all cases, it’s not necessary. The only use-case you need to send provider(s) to a module is when your module is designed in such a way so it creates resources in diff regions or in diff accounts (bad idea)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Creating such a module that creates resources in diff region is OK (in this case you can send it a list of providers that differ by region)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Creating such a module that creates resources in diff accounts is bad idea
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@Andriy Knysh (Cloud Posse) could I show you the problem Im having? I dont have any resources created but i’m still getting the error
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
sounds like you have resources created
To work with
module.somemodule.aws_iam_policy_attachment.codepipeline_policy_attachment its
original provider configuration at module.somemodule.provider.aws.nonprod is
required, but it has been removed. This occurs when a provider configuration
is removed while objects created by that provider still exist in the state.
Re-add the provider configuration to destroy
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
i just ran terraform destroy, no resoruces found
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
could we zoom possibly?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
regarding #6 above: instead of thinking of creating modules that uses providers for diff accounts, it’s better to create yourself an environment which will allow you to login into diff accounts (by using diff profiles in ~./aws
, and eveb better by assuming roles)
2019-09-15
data:image/s3,"s3://crabby-images/89e20/89e20d560545785798114c47a766e9724655051a" alt="SweetOps avatar"
Are you using some of our terraform-modules in your projects? Maybe you could leave us a testimonial! It means a lot to us to hear from people like you.
data:image/s3,"s3://crabby-images/76da9/76da9e3f32fb2f596f0203a030f2a6a8df296c8b" alt="James D. Bohrman avatar"
Hey guys! I’m looking for some advice on how to approach an issue. I’m trying to figure out a way to use Terraform to provision a Windows Server 2016 instance that will run this cloud prep tool once it’s provisioned. I want to do something with Packer down the line but right now I’m just trying to make an easy way to spin up cloud gaming rigs on AWS for myself.
Prep tool: https://github.com/jamesstringerparsec/Parsec-Cloud-Preparation-Tool
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Learn how to run commands on your Windows instances at launch.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Is what you’re after. There are plenty of examples out there on how to pass user-data to an ec2 instance in terraform.
data:image/s3,"s3://crabby-images/76da9/76da9e3f32fb2f596f0203a030f2a6a8df296c8b" alt="James D. Bohrman avatar"
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
@James D. Bohrman this link didn’t work for me.
2019-09-16
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Hi @James D. Bohrman this might help “Deploying a Windows 2016 server AMI on AWS with Packer and Terraform. Part 1” by Bruce Dominguez https://link.medium.com/8hIu8JaK1Z
data:image/s3,"s3://crabby-images/8a18d/8a18d415d8559f9338b53f673c1bae5b790977c7" alt="attachment image"
Automating a deployment of a Windows 2016 Server on AWS should be easy right, after all deploying an ubuntu server with Packer and…
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Does anyone have a good suggestion on creating a snapshot from a Rds database (that’s encrypted) and restoring it to a Dev/testing Env and doing some data scrubbing?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Suggestions yes, any of them any good? Not so sure
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Have seen this done in several ways, none of which were particularly nice
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@Bruce https://github.com/hellofresh/klepto looked interesting in this space last time I checked
Klepto is a tool for copying and anonymising data. Contribute to hellofresh/klepto development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
(probably not a discussion for this particular channel)
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Thanks @joshmyers I will check it out.
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
is anyone able to advise on aws_ecs_task_definition. If I specify multiple containers in the task definition file then neither of the containers come up.
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
but if I have just one it works
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@Mike Whiting you are really going to need to post your instantiation of the Terraform resource or whatever. What you expected. What the actual error message is etc
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
did you mean to @ me?
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
these are the resources:
resource "aws_ecs_task_definition" "jenkins_simple_service" {
// volume {
// name = "docker-socket"
// host_path = "/var/run/docker.sock"
// }
volume {
name = "jenkins-data"
host_path = "/home/ec2-user/data"
}
family = "jenkins-simple-service"
container_definitions = file("task-definitions/jenkins-gig.json")
}
resource "aws_ecs_service" "jenkins_simple_service" {
name = "jenkins-gig"
cluster = data.terraform_remote_state.ecs.outputs.staging_id
task_definition = aws_ecs_task_definition.jenkins_simple_service.arn
desired_count = 1
iam_role = data.terraform_remote_state.ecs.outputs.service_role_id
load_balancer {
elb_name = data.terraform_remote_state.ecs.outputs.simple_service_elb_id
container_name = "jenkins-gig"
container_port = 8080
}
}
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
[
{
"name": "jenkins-gig",
"image": "my-image",
"cpu": 0,
"memory": 512,
"essential": true,
"portMappings": [
{
"containerPort": 8080,
"hostPort": 8000
}
],
"environment" : [
{
"name" : "VIRTUAL_HOST",
"value" : "<host>"
},
{
"name": "VIRTUAL_PORT",
"value": "8080"
}
],
"mountPoints": [
{
"sourceVolume": "jenkins-data",
"containerPath": "/var/jenkins_home",
"readOnly": false
}
]
},
{
"name": "nginx-proxy",
"image": "jwilder/nginx-proxy",
"cpu": 0,
"memory": 512,
"essential": true,
"portMappings": [
{
"containerPort": 80,
"hostPort": 80
}
]
}
]
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
if I remove the nginx-proxy container from the definition then ecs-agent successfully pulls and launches the jenkins container but with it included nothing happens
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
nb: ‘my-image’ is from a private registry and nginx-proxy is public
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Do you have any error events being logged?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Are there creds for the private repo?
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
I’m just observing the ecs-agent logs currently (within the instance)
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
I followed this guide for the private registry stuff https://docs.aws.amazon.com/AmazonECS/latest/developerguide/private-auth-container-instances.html
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
as I say, the container from the private image launches fine when I don’t specifiy the proxy container in the definition file.. i.e. one container object
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
You hadn’t specific which one you can bring up on it’s own, or that one is in a private registry at that point
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
ECS agent logs should give you an idea
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
I can bring up the jenkins container (private image) on it’s own
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
when the nginx-proxy definition is present ecs-agent just sits idle
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
does that make sense?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
yes
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
what do you think I should try?
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
starting to wonder if terraform is really for me if I can’t get help
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
(from anywhere)
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Terraform is just making API calls for you
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
yep
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
The tags for this module are so confusing: https://github.com/cloudposse/terraform-aws-rds/releases
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’ve been using 0.11 by mistake as I took the ‘latest’ tag
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but that’s actually just a hotfix
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
the latest .12 tag ios 0.10
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
true I could have read the list and lesson learned, but had me stumped for a while as to why it wasn’t working!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@oscar don’t pin to master/latest, always pin to a release. In the module, TF 0.12 started with tag 0.10.0
, but when we needed to add some features to TF 0.11 code, we created the tag 0.9.1
which is the latest tag, but not for TF 0.12 code
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yes that’s what I mean
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
a 0.11 tag is at the top of the tags list
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
bamboozled me, logically I would have thought only 0.12 tags would be at the top of the ‘releases’ tab
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s how GitHub works
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
so I had it pinned to a 0.11 until I realised what was going on
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i don’t even see a 0.11 tag in there. there is a 0.11 branch…
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
exactly
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
0.9.1 is a TF 0.11 tag
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
oh you mean the 0.9.1 tag only supports tf 0.11
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
not that there is a 0.11 tag
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Aye
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
confusing
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
bamboozles
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we did not find a better way to support both code bases and tag them
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Haha its fine, I was just pointing out it is a bamboozle
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we started a TF .12 code with some tag and continue incresing it for 0.12
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
It makes sense
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
what you are doing makes sense to me, releasing patch fixes on the 0.9 minor stream
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for 0.11, usually increase the last tag for 0.11 branch
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
The lesson learned was ‘don’t just grab the top most tag’
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
would be cool if tf/go-getter supported more logic in the ref
than an exact committish… a semver comparator (like ~>0.9
) would be awesome
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
tf/go-getter
waht does this do?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
terraform uses go-getter under the covers to retrieve modules specified by source
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I see, yeh that would be smart
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Package for downloading things from a string URL using a variety of protocols. - hashicorp/go-getter
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
checks the versions.tf file and cehcks for compatibility
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Andriy Knysh (Cloud Posse) I think I was doing the PR as you commented! https://github.com/cloudposse/terraform-aws-rds/pull/38
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @oscar, looks good (you even updated the README
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
running automatic tests now, if ok will merge
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
where abouts are your tests?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I couldn’t see them
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I noted Codefresh wasn’t in the PR either
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
testing this example https://github.com/cloudposse/terraform-aws-rds/tree/master/examples/complete
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Oh I see. When I navigated the test/ directory it looked like an example
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but I realise now that examples_complete_test.go
is related ot the examples/ dir
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
and that examples/ isn’t just documentation. Nice
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yah that’s some nice gitops
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I was expecting a trigger
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but that’s cooler
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it is a trigger, but we have to trigger it (for security when dealing with PRs from forks)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Oh that makes sense actually
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
otherwise you could DDOS it
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yeh
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
merged and released 0.11.0
(now you have that tag ) thanks
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
woop, thanks
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Debate/Conversation:
“We should enable deletion_protection for production RDS”
https://www.terraform.io/docs/providers/aws/r/db_instance.html#deletion_protection
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
For: anyone in console / terraform cannot accidentally delete (assuming IAM permissions are not super granular & TF is being operated manually)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Against: presumably this would mean the resource cannot be updated? I’m not too familiar with RDS so unsure on how many settings actually cause a re-create
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
better to enable it, but usually when you want to delete an RDS instance aws takes a snapshot of it as back up.
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
guys do you know when we will have count
enabled for module
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Not seen an ETA yet, just that it is reserved alongside for_each
data:image/s3,"s3://crabby-images/602ca/602ca4ca452eaba13d65ac60c830b01113d0257e" alt="asmito avatar"
?
data:image/s3,"s3://crabby-images/004c6/004c63b2ee6db0afba1d838c774a94adb216bb2e" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Sep 25, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/5ca0e/5ca0efa4585a9475f75db0d17266b5843e629e0c" alt="Mike Whiting avatar"
I’ve had a brainwave that perhaps I need to add another dedicated aws_ecs_service resource for the nginx-proxy - see my example code above. is this a possibility?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Is there a MKS/Kafka module anywhere?
data:image/s3,"s3://crabby-images/a2472/a24724cb69ef0c1864b024b8b77a1b31b75d5a17" alt="Tehmasp Chaudhri avatar"
Has anyone solved a solution for dynamically determining which subnets are free in a given VPC to then use for deploying some infrastructure into? Or know of some examples?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what do you mean by are free
?
data:image/s3,"s3://crabby-images/a2472/a24724cb69ef0c1864b024b8b77a1b31b75d5a17" alt="Tehmasp Chaudhri avatar"
available ip address space
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s not easy
data:image/s3,"s3://crabby-images/a2472/a24724cb69ef0c1864b024b8b77a1b31b75d5a17" alt="Tehmasp Chaudhri avatar"
yup; plus we have multiple cidr blocks (secondaries) being added to the VPC so in some cases the the secondary blocks are barely usable because subnets created off of them don’t garnish many ip address space (e.g. \28)
data:image/s3,"s3://crabby-images/a2472/a24724cb69ef0c1864b024b8b77a1b31b75d5a17" alt="Tehmasp Chaudhri avatar"
so yeah - in those cases basically need a way to filter away “unusable” subnets
data:image/s3,"s3://crabby-images/a2472/a24724cb69ef0c1864b024b8b77a1b31b75d5a17" alt="Tehmasp Chaudhri avatar"
the closet thing i’ve found is running a local cmd and finding a way to stuff it into a data template to somehow use downstream - kind of like the solution here: https://medium.com/faun/invoking-the-aws-cli-with-terraform-4ae5fd9de277
data:image/s3,"s3://crabby-images/a2472/a24724cb69ef0c1864b024b8b77a1b31b75d5a17" alt="Tehmasp Chaudhri avatar"
but all very ugly
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can use https://www.terraform.io/docs/providers/aws/d/subnet_ids.html to get all subnets for a VPC
Provides a list of subnet Ids for a VPC
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
does TF support inline code for lambda functions like cloudformation?
2019-09-17
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
Inside terraform(.tf) i can use assign dynamic stuff using variables like - key_name = "${var.box_key_name}"
for different environments, how can i do the same inside the user-data scripts attached to tf, i am tyring to have unique values for sudo hostnamectl set-hostname jb-*environtmenthere*
in the user-data script
data:image/s3,"s3://crabby-images/e7bb3/e7bb3b61e8d7ebfd5e20ae16c41eb8497b3a1cda" alt="Samuli avatar"
something like this? https://www.terraform.io/docs/providers/template/d/file.html
Renders a template from a file.
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
hi gents, has any one of you succesfully created s3 bucket module with dynamic cors configuration?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not sure what you mean by ‘dynamic configuration’, but take a look here https://github.com/cloudposse/terraform-root-modules/blob/master/aws/docs/main.tf#L79
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
by dynamic configuration, I thought about utilizing terraform’s ‘dynamic’ feature
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
the same approach you linked I use right now but it forces to have any kind of CORS configuration applied to the bucket, even when you do not need CORS at all
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
with dynamic configuration I thought I will be able to create s3 buckets with or without cors configuration
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s easy to implement
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
I ended up with something like this:
dynamic "cors_rule" {
for_each = var.cors_rules
content {
allowed_headers = [lookup(cors_rule.value, "allowed_headers", "")]
allowed_methods = [lookup(cors_rule.value, "allowed_methods")]
allowed_origins = [lookup(cors_rule.value, "allowed_origins")]
expose_headers = [lookup(cors_rule.value, "expose_headers", "")]
max_age_seconds = lookup(cors_rule.value, "max_age_seconds", null)
}
}
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
when variable cors_rules
is a list of maps like this:
cors_rules = [{
allowed_origins = "*"
allowed_methods = "GET"
}]
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
however, this approach is still not perfect, because values not mentioned in the cors_rules
variable will be applied anyway with default values
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
am I missing something ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i don’t think it’s possible to do it, unless you want to use many permutations of dynamic blocks with for_each
with different conditions
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
I see
data:image/s3,"s3://crabby-images/86ef8/86ef8ef9919a60236ccbdfc16e092b9dacfffcbc" alt="PiotrP avatar"
thanks for answering
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s how we deploy https://docs.cloudposse.com/
data:image/s3,"s3://crabby-images/76da9/76da9e3f32fb2f596f0203a030f2a6a8df296c8b" alt="James D. Bohrman avatar"
Here’s a little tool I’ve been working on that the gamers here might like. I used a lot of Cloud Posse modules also
Terraform module for deploying a Parsec Cloud Gaming server. - jdbohrman/parsec-up
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for discoverability, have you considered renaming it to terraform-aws-parsec-instance
? this is the format hashicorp suggests for the registry
Terraform module for deploying a Parsec Cloud Gaming server. - jdbohrman/parsec-up
data:image/s3,"s3://crabby-images/76da9/76da9e3f32fb2f596f0203a030f2a6a8df296c8b" alt="James D. Bohrman avatar"
I haven’t but I will probably do that!
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
@Andriy Knysh (Cloud Posse) finally so apparently A) Terraform state loading is private to itself in the UI and Command code, so I will need to talk to either paul or terraform team about it, B) and good news finally find out that loading in terraform is implicit cascading
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
terraform will declare main.tf to be empty
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
and skip reading
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
is useful, since I need it to do resource & data types gathering for error checking
2019-09-18
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Anyone seen the issue where you curl from an EKS worker node to the cluster and get SSL issues?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Using CP worker / cluster / asg modules.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
curl: (60) SSL certificate problem: unable to get local issuer certificate
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
… this is curling the API endpoint as per EKS
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Addison Higham I’m using your branches from here https://sweetops.slack.com/archives/CB6GHNLG0/p1566415698381800
Error: Invalid count argument
on .terraform/modules/eks_workers.autoscale_group/ec2-autoscale-group/main.tf line 120, in data "null_data_source" "tags_as_list_of_maps":
120: count = var.enabled ? length(keys(var.tags)) : 0
The "count" value depends on resource attributes that cannot be determined
until apply, so Terraform cannot predict how many instances will be created.
To work around this, use the -target argument to first apply only the
resources that the count depends on.
for the cloudposse modules, I got all these working with 0.12: https://github.com/cloudposse/terraform-aws-ec2-autoscale-group/pull/14 https://github.com/cloudposse/terraform-aws-eks-workers/pull/21 https://github.com/cloudposse/terraform-aws-eks-cluster/pull/20
I forgot to update the version for CI to 0.12, will try and push that out
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but getting the following error. Could you provide any guidance on what you think that might be?
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
yeah, that was an oopsie, a fix got merged… but maybe it didn’t make it onto the branch I was trying to upstream
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
lemme find it
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Thanks. If possible could you push it to your fork’s master? :slightly_smiling_face: I did try your inst-*
branch but that didn’t seem to quite fix it
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
oh that is a different issue @oscar, what are you passing to tags? as the error message says, it can’t have anything dynamic being passed in
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
tags is actually empty
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I’m passing var.tags which is an empty {} in my terraform proejct that calls your eks_worker module
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
so am I correct in using your worker & cluster branches @master branch?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
because I’m aware you also have the ASG one updated, but do the master branches of worker and cluster point to that?
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
oh yeah, so that is why we use the inst-version
, which does this: https://github.com/instructure/terraform-aws-eks-cluster/pulls?utf8=%E2%9C%93&q=is%3Apr
Terraform module for provisioning an EKS cluster. Contribute to instructure/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
to be safe, whenever I change refs, I also just delete .terraform
directory and re-init
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
it is sorta weird, we didn’t want to open a PR to our updated module, but they do need to merge them in order for these to work
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Ya I understand the need for the branch. I’ll give another go later on.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
So worker inst Cluster master
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
And that should fix my previous issue with count?
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
I think so? at least that is what we have and don’t have any issues
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
public #office-hours starting now! join us to talk shop https://zoom.us/j/508587304
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Addison Higham - darn still got the same issue
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
module "eks_cluster" {
source = "git::<https://github.com/instructure/terraform-aws-eks-cluster.git?ref=master>"
...
}
module "eks_workers" {
source = "git::<https://github.com/instructure/terraform-aws-eks-workers.git?ref=inst-version>"
...
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
same error?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yeh
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Error: Invalid count argument
on .terraform/modules/eks_workers.autoscale_group/main.tf line 120, in data "null_data_source" "tags_as_list_of_maps":
120: count = var.enabled ? length(keys(var.tags)) : 0
The "count" value depends on resource attributes that cannot be determined
until apply, so Terraform cannot predict how many instances will be created.
To work around this, use the -target argument to first apply only the
resources that the count depends on.
module "eks_workers" {
source = "git::<https://github.com/instructure/terraform-aws-eks-workers.git?ref=inst-version>"
namespace = var.namespace
stage = var.stage
name = var.name
tags = var.tags
...
}
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
var.tags is empty (defaulting to {}
)
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
is your cluster_name
dynamic? see https://github.com/instructure/terraform-aws-eks-workers/blob/master/main.tf#L2, the workers module computes some tags, so your cluster_name needs to be known at plan time
Terraform module to provision an AWS AutoScaling Group, IAM Role, and Security Group for EKS Workers - instructure/terraform-aws-eks-workers
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Omg
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
that must be it
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
that is why in the example you see them use the label
module to compute the name of the cluster in multiple distinct places
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Interestingly though… https://github.com/cloudposse/terraform-root-modules/blob/master/aws/eks/eks.tf#L77
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
# mine
cluster_name = "${module.eks_cluster.eks_cluster_id}"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Will hardcode to a string for now
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Super thanks. Cluster and workers up now
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
But back to workers not connecting to cluster.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@oscar did you apply this https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/kubectl.tf ?
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Ah - no thank you. I saw this before but didn’t honestly understand it! Should this be run at cluster creation or can be applied afterwards?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so at the time we did it, in some cases there were some race conditions, that’s why we did not enable it by default
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
after the cluster applied, we set the var to true
and applied that
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Many thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but now you can test it with the var enabled from start
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we did that almost a year ago so a lot prob has changed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and we will convert the EKS modules to 0.12 and add auto-tests this/next week (finally )
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Would love to get a hold of those updated modules
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Andriy you are my hero
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
My workers are now connected
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
TF weirdly got an unauthorized response when applying the command:
kubectl apply -f config-map-aws-auth-xxx-development-eks-cluster.yaml --kubeconfig kubeconfig-xxx-development-eks-cluster.yaml
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
but my kubectl already had the context activated
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
so I just ran the apply configmap without the –kubeconfig
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
@Andriy Knysh (Cloud Posse) XD XD XD XD XD, so I found the biggest issue that is causing vs code users for using the terraform lsp plugin, I forgot to omit the hover provider from the first release that I was trying out(so is very error prone), since I only use vim, so there is no hover that get activated
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
so now is alot more stable for any GUI based Editor that is going to use terraform-lsp
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
nice @Julio Tain Sueiras
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@justingrote btw, didn’t realize you were on sweetops. We discussed your comment today #office-hours today https://github.com/hashicorp/terraform/issues/15966#issuecomment-520102463 (@sarkis had originally directed my attention to it)
Feature Request Terraform to conditionally load a .tfvars or .tf file, based on the current workspace. Use Case When working with infrastructure that has multiple environments (e.g. "staging&q…
data:image/s3,"s3://crabby-images/c293e/c293e54248d3f8f14e71efa87d58eaa07c82e2e9" alt="justingrote avatar"
@justingrote has joined the channel
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
i am facing issues with pre-commit
when using in my terraform project
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
repos:
- repo: <git://github.com/antonbabenko/pre-commit-terraform>
rev: v1.15.0
hooks:
- id: terraform_fmt
- id: terraform_docs_replace
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
i receive the following error
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
pkg_resources.DistributionNotFound: The 'pre-commit-terraform' distribution was not found and is required by the application
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
any ideas on what could be the problem ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@antonbabenko
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
@rohit Not sure if it will fix anything, but you can try changing the git://
to https://
. Here’s mine for reference:
- repo: <https://github.com/antonbabenko/pre-commit-terraform>
rev: v1.19.0
hooks:
- id: terraform_fmt
- id: terraform_docs
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
i think the problem is with terraform_docs_replace
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
and maybe it has terraform version 0.11.13
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
i want to replace the README file automatically as part of commit
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
do you know if the same can be achieved using terraform_docs
?
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
its possible. I contributed terraform_docs_replace
several months ago, it probably hasn’t been touched since then.
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
i think terraform_docs_replace
is only supported in terraform v12
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
terraform_docs
just makes changes to an existing README between the comment needles
<!-- BEGINNING OF PRE-COMMIT-TERRAFORM DOCS HOOK -->
stuff gets changed here
<!-- END OF PRE-COMMIT-TERRAFORM DOCS HOOK -->
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
terraform_docs_replace
was made quite a while ago, before 12 came out
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
when i update variables and their description in [variables.tf](http://variables.tf)
, my README.md files does not gets updated using terraform_docs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform by HashiCorp
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
good read
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
if ive got a module such as:
module "vpc_staging" {
source = "./vpc_staging"
}
can I access a variable/output created in that module in another module like so?
module "security-group" {
source = "terraform-aws-modules/security-group/aws"
version = "1.25.0"
name = "sg"
description = "Security group for n/w with needed ports open within VPC"
vpc_id = "${module.vpc_staging.vpc_id}"
}
Would I use the variable name, or output id? What do I reference basically?
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
The second module can use the outputs of the first module. So, the vpc_staging module would need an output
called vpc_id
for that example you gave.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
right! I thought so, just wanted to confirm
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
thanks
data:image/s3,"s3://crabby-images/09ab1/09ab199dd9b71a729809f8f5599389371b3111d2" alt="Claudio Palmeira avatar"
Hey guys, I do have a problem with the examples on the eks_cluster, more specifically on the subnets module It has an unssoported argument there:
data:image/s3,"s3://crabby-images/09ab1/09ab199dd9b71a729809f8f5599389371b3111d2" alt="Claudio Palmeira avatar"
An argument named “region” is not expected here.
data:image/s3,"s3://crabby-images/09ab1/09ab199dd9b71a729809f8f5599389371b3111d2" alt="Claudio Palmeira avatar"
unsupported
data:image/s3,"s3://crabby-images/09ab1/09ab199dd9b71a729809f8f5599389371b3111d2" alt="Claudio Palmeira avatar"
module subnets on main.tf: this line -> region = “${var.region}” Terraform complains about it not being an expected argument
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the example is not actually correct since the EKS modules are TF 0.11, but the subnet module are pinned to master which is already 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we are working on converting EKS modules to 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for now, pin the subnet module to a TF 0,11 release
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
module "subnets" {
source = "git::<https://github.com/cloudposse/terraform-aws-dynamic-subnets.git?ref=tags/0.12.0>"
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
same with https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/main.tf#L37
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
pin to 0.4.1
which is TF 0.11
data:image/s3,"s3://crabby-images/09ab1/09ab199dd9b71a729809f8f5599389371b3111d2" alt="Claudio Palmeira avatar"
Thank you mate
2019-09-19
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
How come only the creator of the EKS cluster can connect using the CP moduels?
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
By default, only the creator of the cluster has access to it using IAM. The aws-auth
ConfigMap in the kube-system namespace controls it. You can add an IAM role mapped to a K8s group that will give anyone who is able to assume that role the ability the log in. Looks like CloudPosse’s implementation of the terraform-aws-eks-workers
module doesn’t make this configurable yet.
Looks like the template for the ConfigMap is here: https://github.com/cloudposse/terraform-aws-eks-workers/blob/master/config_map_aws_auth.tpl
The EKS cluster example shows it being applied here: https://github.com/cloudposse/terraform-aws-eks-cluster/blob/master/examples/complete/kubectl.tf
Here’s an example of what it would look like with an IAM role bound to a K8s group that would give anyone that is able to assume the role my-eks-cluster-admin
the ability to log into the cluster with cluster-admin privileges:
apiVersion: v1
kind: ConfigMap
metadata:
name: aws-auth
namespace: kube-system
data:
mapRoles: |
- rolearn: arn:aws:iam::REDACTED:role/REDACTED
username: system:node:{{EC2PrivateDNSName}}
groups:
- system:bootstrappers
- system:nodes
- rolearn: arn:aws:iam::REDACTED:role/my-eks-cluster-admin
username: my-eks-cluster-admin
groups:
- system:masters
mapUsers: |
mapAccounts: |
Then, you would change the command being run in your kubeconfig to use the role by using the -r
flag in the aws-iam-authenticator token
command.
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
Be advised that this will defeat some auditability because Kubernetes will see everyone as the user my-eks-cluster-admin
. You can do a very similar thing with the mapUsers
section in order to map each user you want to give access to with a username in Kubernetes.
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
The syntax for mapUsers
is
mapUsers: |
- userarn: <theUser'sArn>
username: <TheUsernameYouWantK8sToSee>
groups:
- <TheK8sGroupsYouWantTheUserToBeIn>
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Thank you we found the answer to this earlier on! Really apporeciate your detail!
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
We’re planning to fork it when 0.12 of the module goes live to support this customizability
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks guys, we will add additional roles and users mapping (working on 0.12 of the modules now)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Ah that’s cool. My new firm is really keen to use CP’s own version of 0.12 (not the fork/PR branch). We have our own customizability reqs so once 0.12 is done and pushed we can start extending
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
https://github.com/hashicorp/terraform/issues/22649 anyone experiencing this out of nowhere? (All devs using the state file are on 0.12.6)
Terraform Version v0.12.7 Debug Output Error: Error loading state: state snapshot was created by Terraform v0.12.7, which is newer than current v0.12.6; upgrade to Terraform v0.12.7 or greater to w…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they have been busy adding new features
Terraform Version v0.12.7 Debug Output Error: Error loading state: state snapshot was created by Terraform v0.12.7, which is newer than current v0.12.6; upgrade to Terraform v0.12.7 or greater to w…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
usually that happened when using 0.12 then trying to read the state with 0.11
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but now looks like any version bump causes that
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
But everyone (2 people - we’re next to eachother) using that project are using the same geodesic shell and have the same version 0.12.6… yet the statefile in S3 says 0.12.7 O.O
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
neither of us have 0.12.7 which is super weird
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
geodesic
has 0.12.6 as well?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
yep!
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
or rather
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
we are both in geodesic
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
and terraform version
is 0.12.6 on both our PCs
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
No one else feasibly ran this
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
inside geodesic
, terraform version
is 0.12.6 as well?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Yes
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
on our locals: 0.12.0
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
on our geodesics: 0.12.6
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Whilst we’d like to know why, we’re happy to use 0.12.9 etc
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
.. but we’re using cloudposses terraform_0.12
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Andriy Knysh (Cloud Posse) I see that 0.12.7 is in your packages https://github.com/cloudposse/packages/blob/master/vendor/terraform-0.12/VERSION
however apk add –update –no-cache terraform_0.12 does not work as expected
Cloud Posse installer and distribution of native apps, binaries and alpine packages - cloudposse/packages
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
Ok updated my geodesic FROM to 0.122.4 and that cleared the cache
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
now on 0.12.7
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
i thought you needed apk update && apk add --update terraform_0.12@cloudposse
is the @cloudposse
not required?
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
doh that must be it
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
merci beaucoup
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
granted, using the newest geodesic is also nice~ features and bugfixes, oh my
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
I was only coming from 0.119 - not that far behind!
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
I also usually customize that in my own dockerfile that wraps geodesic:
RUN apk add terraform_0.12@cloudposse terraform@cloudposse==0.12.7-r0
Is what’s in ours, but we only have one or two 0.12 projects, everything is mostly on 0.11 still
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
stupid question I’m using
locals {
availability_zones = slice(data.aws_availability_zones.available.names, 0, 2)
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but sometimes my resources end up in the same AZ
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
better to just hardcode them ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@jose.amengual what do you mean by sometimes
? When in diff regions?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the code above is ok and should work
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
same region
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no need to hardcode anything
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m using the terraform terraform-aws-rds-cluster
module
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
which I’m going to send a PR to support global clusters
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you have to make sure you create the subnets in diff AZs https://github.com/cloudposse/terraform-aws-rds-cluster/blob/master/examples/complete/main.tf#L40
Terraform module to provision an RDS Aurora cluster for MySQL or Postgres - cloudposse/terraform-aws-rds-cluster
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that example worked many times
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I know is weird because if I recreate the cluster then it will work
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I wonder now….maybe I just have a problem in one region
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we use TF to create the accounts so in every region we subnets for every AZ
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I was wondering if for some reason we made a mistake or something
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but I’m using a data lookup to find them base on tags
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea check the data lookup if it returns the correct result
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
exactly what I’m doing
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m gettin 3 subnet ids in us-east-1 and 4 in us-west-2
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so the data lookups are good
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hmm… maybe we need to specify AZs now https://www.terraform.io/docs/providers/aws/r/rds_cluster.html#availability_zones
Manages a RDS Aurora Cluster
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
cluster_size = 2 and I pass 4 subnets, then it should be ok
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
Has anyone else run into the issue where you can’t pass variables via the command line when using the remote backend since last week when they released terraform cloud?
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
Error: Run variables are currently not supported
The "remote" backend does not support setting run variables at this time.
Currently the only to way to pass variables to the remote backend is by
creating a '*.auto.tfvars' variables file. This file will automatically be
loaded by the "remote" backend when the workspace is configured to use
Terraform v0.10.0 or later.
Additionally you can also set variables on the workspace in the web UI:
<https://app.terraform.io/app/Boulevard/sched-dev-feature-branch-environments/variables>
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Global cluster support PR @Andriy Knysh (Cloud Posse) https://github.com/cloudposse/terraform-aws-rds-cluster/pull/56
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @jose.amengual
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
commented
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
fixed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
did you run
make init
make readme/deps
make readme
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
looks like README was not updated
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and docs/terraform.md
was deleted
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
weird
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmm
❰jamengual❙~/github/terraform-aws-rds-cluster(git:globalclusters)❱✔≻ make readme 5.2s Thu 19 Sep 18:51:17 2019
curl --retry 3 --retry-delay 5 --fail -sSL -o /Users/jamengual/github/terraform-aws-rds-cluster/build-harness/vendor/terraform-docs <https://github.com/segmentio/terraform-docs/releases/download/v0.4.5/terraform-docs-v0.4.5-darwin-amd64> && chmod +x /Users/jamengual/github/terraform-aws-rds-cluster/build-harness/vendor/terraform-docs
2019/09/19 18:51:24 At 3:16: Unknown token: 3:16 IDENT var.namespace
make: *** [docs/terraform.md] Error 1
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hmmm
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
looks like something is broken (will have to look)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Looks like an old build harness
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
The ident error tells me that it’s using an old version of terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform-docs does not support it natively, so we have a wrapper around terraform docs
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ohhhh
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
one sec
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I have two binaries
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Also might get fixed if you blow away build harness and rerun make init. Just a hunch.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(On my phone so cant provide more detail)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
done
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Unknown token: 3:16 IDENT
happened to me when TF versions mismatched
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
thanks guys
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
tested on AWS and merged
data:image/s3,"s3://crabby-images/c026c/c026c40f70a7f82cb6d39db55ade6f8b7e803e7e" alt="cytopia avatar"
I am currently working on a new fix for the terraform-docs.awk
wrapper here: https://github.com/antonbabenko/pre-commit-terraform/issues/65
If there are any other issues coming up, let me know
How reproduce Working code: staged README.md <!– BEGINNING OF PRE-COMMIT-TERRAFORM DOCS HOOK –> <!– END OF PRE-COMMIT-TERRAFORM DOCS HOOK –> staged vars.tf variable "ingress_ci…
2019-09-20
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
Azure
Hi everyone, I’m about to move my big terraform configuration into separate modules, but I have a question about best practice regarding resource-groups.
If I will create resource-group
resource in every of my modules, it will be fine, because it will be created once, but when for some reason I will remove entire module or I will try to redeploy it, wouldn’t Terraform want to delete my resource group (and all other resources-modules)? Should I rather use data
resource to make reference to resource group created in another module or what are your ideas?
Thanks
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
hey guys… not sure whats going on but it looks like the 0.9.0 - terraform-aws-cloudfront-s3-cdn module is creating ARN IDs like
“arniam:user/CloudFront Origin Access Identity XXXXXXXXXXXXXXXX”
for S3 policies to allow Cloudfront access
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
ah that’s a new issue
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
I just encountered it today
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
oh thank god.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
AWS changed how the API behaves
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
in the background
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
if you need a quick fix
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
I literally thought i was going crazyh
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
hahah it happened to me as well
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
i do ,. please
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
sec
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Community Note Please vote on this issue by adding a reaction to the original issue to help the community and maintainers prioritize this request Please do not leave "+1" or "me to…
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
the glorious fix is
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
aaaaah
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
can i just downgrade my provider version?
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
lets take a peak
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
principals {
type = "AWS"
identifiers = [replace("${aws_cloudfront_origin_access_identity.this.iam_arn}", " ", "_")]
}
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
Thank you!
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
for now you should be able to patch it until @Andriy Knysh (Cloud Posse) or @Erik Osterman (Cloud Posse) wake up and officialy fix it
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
haha Erik is a long time friend of mine, i can hold something over him i think to get it fixed
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
although, I was the one who was usually embarrassing themselves…
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
I think using the replacements only works for current state files, if you’re doing new policies you have to use type CanonicalUser and identifier s3_canonical_user_id
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
aaaah
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
nope that’s not going to work
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
It just applied for me.
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
even though CanonicalUser and identifier s3_canonical_user_id will pass tf apply
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
try it again
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
aws is changing it in the background
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
you’ll get a change on every apply
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
really
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
ugh
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
at least that’s what happened to me
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
Apply complete! Resources: 0 added, 1 changed, 0 destroyed.
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
damn
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
It wont take the replace suggestion, keeps telling me bad
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
Error: Error putting S3 policy: MalformedPolicy: Invalid principal in policy
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
gonna try something
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
it was too early, i was using dashes lol….
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
underscores work
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
thanks for the help Nikola!
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
gonna lurk here now….
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
you are welcome
2019-09-22
data:image/s3,"s3://crabby-images/3e223/3e2237fd1c384cc564e492e3c51087056d288087" alt="guigo2k avatar"
guys, any update on this https://sweetops.slack.com/archives/CB6GHNLG0/p1566415698381800 ? Really looking forward to use these modules with TF 0.12
for the cloudposse modules, I got all these working with 0.12: https://github.com/cloudposse/terraform-aws-ec2-autoscale-group/pull/14 https://github.com/cloudposse/terraform-aws-eks-workers/pull/21 https://github.com/cloudposse/terraform-aws-eks-cluster/pull/20
I forgot to update the version for CI to 0.12, will try and push that out
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, we are working on that now, will be done in the next 2-3 days
for the cloudposse modules, I got all these working with 0.12: https://github.com/cloudposse/terraform-aws-ec2-autoscale-group/pull/14 https://github.com/cloudposse/terraform-aws-eks-workers/pull/21 https://github.com/cloudposse/terraform-aws-eks-cluster/pull/20
I forgot to update the version for CI to 0.12, will try and push that out
data:image/s3,"s3://crabby-images/3e223/3e2237fd1c384cc564e492e3c51087056d288087" alt="guigo2k avatar"
thanks for the update @Andriy Knysh (Cloud Posse)
2019-09-23
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
If I create NATs in one module, is there a way to get a list of NAT GW and pass it to a new sg with TF?
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Your module can output the list of NAT GWs and you can do whatever you desire with that list
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
is that only if I am creating that sg within the same module?
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Nope.
So there are levels. Think of them as boxes. Terrafrom resources have attributes( variables you set say, ami_name
for an EC2 instance) and outputs( say instance_name
). You can take that output and play around with it in the same module. Or you can get that output and push it out of your module — your module now outputs that value too.
data:image/s3,"s3://crabby-images/334be/334be9a7546b0e2999fea3f1bfa760b4590418e4" alt="Vlad Ionescu (he/him) avatar"
Output values are the return values of a Terraform module.
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
Thank you! Is there another way to do it with using just data? like data aws_nat_gatway and then scrape for a list with tags
data:image/s3,"s3://crabby-images/94cd6/94cd65c473ac77ce8704014ffb423c9e1d29ff3b" alt="russell.t.sherman avatar"
there are examples in terraform-root-modules of reading the output of other modules using their remote state.. https://github.com/cloudposse/terraform-root-modules/blob/9301b150c89a5543bdd2785ecdacf000ee6c5561/aws/iam/audit.tf#L15
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3e223/3e2237fd1c384cc564e492e3c51087056d288087" alt="guigo2k avatar"
@pericdaniel I believe this post will answer your questions https://blog.gruntwork.io/how-to-manage-terraform-state-28f5697e68fa#7077
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
Thank you!
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
@Andriy Knysh (Cloud Posse) https://github.com/cloudposse/terraform-aws-rds/pull/41
why To use this module and not cause a re-creation, you would have to hardcode the password somewhere in your config / terraform code. This is not a secure method. Naturally if you use a secrets sy…
data:image/s3,"s3://crabby-images/004c6/004c63b2ee6db0afba1d838c774a94adb216bb2e" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Oct 02, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
Hi guys,
Any of you has experience with maintenance of SaaS environments? What I mean is some dev, test, prod environments separate for every Customer?
In my case, those environments are very similar, at least the core part, which includes, vnet, web apps in Azure, VM, storage… All those components are currently written as modules, but what I’m thinking about is to create one more module on top of it, called e.g. myplatform-core
. The reason why I want to do that is instead of copying and pasting puzzles of modules between environments, I could simply create env just by creating/importing my myplatform-core
module and passing some vars like name, location, some scaling properties.
Any thoughts about it, is it good or bad idea in your opinion?
I appreciate your input.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the idea is good. That’s how we create terraform environments (prod, staging, dev, etc.). We have a catalog of terraform modules (just code without settings/configs). Then for each env, we have a separate GitHub repo where we import the modules we need (using semantic versioning so we know exactly which version we are using in which env) and provide all the required config/settings for that environment, e.g. AWS region, stage (prod, staging, etc.), and security keys (from ENV vars or AWS SSM)
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
As I understand, you’re actually not creating a Terraform Module of your core/base infra, but instead you have catalogs/repos per environment with versioned “module puzzles”?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for example, we have a catalog of TF modules - reusable code which we can use in any env (prod, staging, dev, testing) https://github.com/cloudposse/terraform-root-modules/tree/master/aws
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the code does not have any identity, it could be deployed anywhere after providing the required config/settings
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then for example, in testing env, we create projects for the modules we need (e.g. eks
), https://github.com/cloudposse/testing.cloudposse.co/blob/master/conf/eks
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and load the module code from the catalog https://github.com/cloudposse/testing.cloudposse.co/blob/master/conf/eks/.envrc (uisng semantic versioning)
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but all the config/settings are provided from a few places:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Dockerfile (in which we have settings common for all modules in the project) https://github.com/cloudposse/testing.cloudposse.co/blob/master/Dockerfile
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Secrets are from ENV vars (which get populated from diff sources, e.g. AWS SSM, Secrets Manager, Vault, etc.) when the CI/CD deployment pipeline runs, or on dev machine by executing some commands)
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
I see, thank you very much I started with different approach, I keep all my environments in one Terraform Repository with projects and I include modules from external git repositories (each module in separate git repository)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s what we do too
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
https://github.com/cloudposse/terraform-root-modules is a (super)-catalog of top level modules which are aggregations of low-level modules
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
each projects in there connects low-level modules together into a reusable top-level module https://github.com/cloudposse/terraform-root-modules/blob/master/aws/eks/eks.tf#L31
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
ah, right
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
those aggregations are opionated since you can have many diff ways to connect low-level modules to create a top-level module you need
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
Interesting approach. I was reading quite a lot recently, best practices with Terraform,TF Up & Running etc. and in most cases people don’t recommend using nested modules, but it looks really reasonable in your case.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they are not nested (in that sense)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
those are module instantiation and connecting them together into a bigger module
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s why we have modules in TF - to reuse them
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in other modules
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
Actually that was my understanding of nested word, sorry. English is not my first language
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
By nested modules, they mean modules of modules. Cloudposse stuff does use modules of modules e.g. module A may use module B, and module B may use module C
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
It works fine, but can be interesting to debug several layers down
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
If you want composable modules, there isn’t much of a way around that
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
data:image/s3,"s3://crabby-images/ab4b0/ab4b07a2b0275bfab7d75319dcf614abf2fd1a45" alt="Vlady Veselinov avatar"
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
Any samples/examples for implementing Cloudwatch events>create new rule>Ec2 Instance State-Change Notification > Target > SNS > email
, currently going through official docs
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
@Hemanth you cannot create email subscription to an SNS topic with terraform, because they require a confirmation
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Hey All, has anyone had issues creating azure resources with an s3 backend?
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
@Andriy Knysh (Cloud Posse) have you ever used an s3 backend with other providers for resources? I’m getting an issue where my declared resources are being pick up in the state file
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
did not use azure, but you can give more details about the issue, maybe somebody here will have some ideas
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Otherwise, you just want to create the following resources: aws_cloudwatch_metric_alarm, aws_sns_topic, and aws_sns_topic_subscription
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
maybe you could find some ideas from https://github.com/cloudposse?utf8=%E2%9C%93&q=alarm&type=&language=
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Hemanth ^
data:image/s3,"s3://crabby-images/bef0a/bef0ab8a8f47fbd57aa7553b6e8029dff04dfeba" alt="Hemanth avatar"
@Andriy Knysh (Cloud Posse) the https://github.com/cloudposse/terraform-aws-ec2-cloudwatch-sns-alarms is empty. but thanks those samples are helpful
Terraform module that configures CloudWatch SNS alerts for EC2 instances - cloudposse/terraform-aws-ec2-cloudwatch-sns-alarms
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that one was not implemented
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
2019-09-24
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
re: https://github.com/cloudposse/terraform-aws-cloudfront-s3-cdn/pull/51 @Andriy Knysh (Cloud Posse) if you make this change every terraform plan will produce a change
data:image/s3,"s3://crabby-images/c0c11/c0c11fe6af07639e80cfa80f6580c3f0e01192d5" alt="gyoza avatar"
you just need to replace ” “, “_” on the old value
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
You guys using terraform cloud at all yet?
data:image/s3,"s3://crabby-images/0ae60/0ae60c397ea2792a92625662cebd804a66b1d680" alt="pete avatar"
What are the overall benefits?
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
Visualization into runs via the web UI. You can see whats been applied recently and how that run went.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
You can lock down certain users, you can also plan/apply automatically based on changes to git.
data:image/s3,"s3://crabby-images/0ae60/0ae60c397ea2792a92625662cebd804a66b1d680" alt="pete avatar"
Interesting. I’ll have to check it out. Used to getting the auto features baked into my CI workflow, so if tf-cloud can potentially simplify that, it could be a win.
data:image/s3,"s3://crabby-images/0ae60/0ae60c397ea2792a92625662cebd804a66b1d680" alt="pete avatar"
Does the visualization piece look at anything outside the tf-state?
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Using #atlantis for now, as it is more flexible
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Though terraform cloud does look appealing
data:image/s3,"s3://crabby-images/9b747/9b7470c8245cf2b979f3559aab2f6c334fa1257d" alt="leonawood avatar"
Can you use terraform_remote_state data source as an input attribute for subnet in the cloudposse aws ec2 module?
data:image/s3,"s3://crabby-images/9b747/9b7470c8245cf2b979f3559aab2f6c334fa1257d" alt="leonawood avatar"
I am using the terraform approved aws vpc module to create my VPC, and have correctly setup all my outputs, one specific being a public_subnet ID and I am trying to reference said subnet ID as a terraform_remote_state data source as the subnet attribute but am not sure of the proper syntax
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@leonawood take a look here https://sweetops.slack.com/archives/CB6GHNLG0/p1569238378151700
If I create NATs in one module, is there a way to get a list of NAT GW and pass it to a new sg with TF?
data:image/s3,"s3://crabby-images/9b747/9b7470c8245cf2b979f3559aab2f6c334fa1257d" alt="leonawood avatar"
data:image/s3,"s3://crabby-images/9b747/9b7470c8245cf2b979f3559aab2f6c334fa1257d" alt="leonawood avatar"
thank you!
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I have a terraform module in which we use to setup new AWS accounts with certain resources. So this module is generic enough to use on ‘dev’ aws account, ‘qa’ account and ‘prod’ account for say. However, I need to only create some resources based on the environment. How can I achieve this with a module? I saw this online: https://github.com/hashicorp/terraform/issues/2831
We have a couple of extra terraform resources that need creating under certain conditions. For example we use environmental overrides to create a "dev" and a "qa" environment fr…
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
is this still the best way?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
was about to try that out but read that if the count is set to 0, it would destroy the resource ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for all resources in the module, you could use count = var.environment == "prod" ? 1 : 0
or count = var.environment == "qa" ? 1 : 0
etc.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or any combination of the conditions
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
so adding count = var.environment == "prod" ? 1 : 0
would ensure the resource is only created in prod?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it will ensure that if var.environment == "prod"
then the resource will be created. If you run it in prod
, it will be in prod.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
at the same time, you could make a mistake and set var.environment == "prod"
and run it in dev
, then it will be created as well in dev
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Brij S you need some kind of container (or separate repo) where you set all configs for let’s say prod
(e.g. region and AWS prod account ID) and where you set var.environment == "prod"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you run it, it will be used only in the prod account and since var.environment == "prod"
, the resource will be created
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so a better strategy would be not to create a super-giant module with many conditions to create resources or not
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
divide the big module into small modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then use some tools to combine only the required modules into each account repo
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the tool could be terragrant
or what we do using geodesic
and remote module loading https://www.reddit.com/r/Terraform/comments/afznb2/terraform_without_wrappers_is_awesome/
One of the biggest pains with terraform is that it’s not totally 12-factor compliant (III. Config). That is,…
data:image/s3,"s3://crabby-images/9b747/9b7470c8245cf2b979f3559aab2f6c334fa1257d" alt="leonawood avatar"
anyone here split up state files? we use tf workspaces and it works quite nicely. I am interested if theres a way to combine all the outputs into one file tho for reference?
data:image/s3,"s3://crabby-images/9b747/9b7470c8245cf2b979f3559aab2f6c334fa1257d" alt="leonawood avatar"
so I can just send to our sys admin and it contain all the relevant details
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@Andriy Knysh (Cloud Posse) i will look into terragrunt, as for now Id like to use the above suggestion with TF11, but having some issue with syntax:
${var.aws_env} == "prod" ? "1" : "0"
doesnt work - what am i missing?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
"${var.aws_env == "prod" ? 1 : 0}"
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
what about the closing }
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
need it too
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
cool let me try that
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
PR for more alb ingress config options: https://github.com/cloudposse/terraform-aws-alb-ingress/pull/22
Feature Added the following with sensible defaults to not break the current consumers: health check variables to enable/disable and control the port + protocol slow_start stickiness // CC @aknysh…
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I did not check the provider versions so unsure if it’ll break consumers or not
Feature Added the following with sensible defaults to not break the current consumers: health check variables to enable/disable and control the port + protocol slow_start stickiness // CC @aknysh…
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
added a simple example too
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @johncblandii
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an HTTP style ingress rule based on hostname and path for an ALB using target groups - cloudposse/terraform-aws-alb-ingress
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
no prob
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
is there a way to create an IAM user, generate access keys and plug them into paramstore with terraform?
2019-09-25
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Components for secure UI hosting in S3
• S3 — for storing the static site
• CloudFront — for serving the static site over SSL
• AWS Certificate Manager — for generating the SSL certificates Route53 — for routing the domain name to the correct location Did anyone come across any modules for this in terraform ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
thankq @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
S3-backed serverless PyPI. Contribute to amancevice/terraform-aws-serverless-pypi development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
Hi all,
I’ve been using terraform (0.10 & 0.11) for close to three years now and as terraform 0.12 gets more support/becomes more of the industry standard, my team is looking to adopt it in a way where we can rearchitect our terraform structure, and reduce the general number of pain points across the team.
Currently we are a multi-region AWS shop that has single terraform repos for every service we deploy, with modules at the root of the repo, and directories representing each of our environments (qa-us-east-1, qa-eu-west-1). We run terraform from within those environment specific directories and push remote state to S3 to maintain completely separate state.
We’re thinking about how we can merge all of this into a single repo where:
- There are modules that can be reused across all of our different services (they’d either live at the root of the base terraform repo or in a separate terraform modules repo that we can reference from within our base repo)
- We duplicate as little code as possible (probably obvious but still worth mentioning)
- We continue to keep all state separate on a per environment basis
- Follow terraform best practices to make sure that upgrade paths continue to be easy/straightforward
We also want to keep in mind that we are shifting to a multi account AWS organization where our terraform will be deploying into different AWS accounts as well.
The team so far has demoed both Terragrunt and Terraform Workspaces. We are also considering not using workspaces or Terragrunt but still migrating to the single repo structure. There have been mixed opinions about all options considered. I’d love to get feedback from the community if anyone has opinions based on current or previous experiences with either.
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
Please note that we are currently not using Terraform Enterprise but that has been an option that could be considered as well
data:image/s3,"s3://crabby-images/29c49/29c4978b455a1419f92ef0f771c3c60a504a066b" alt="Tom de Vries avatar"
Regarding the multiple AWS account, we have a similar setup where, depending on the env directory you’re in, we hop into the correct AWS Account. Would that work for you are are you planning on deploying the same environment within multiple accounts?
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
it would be different environments within multiple accounts. The rough plan is to have each of our teams have a production & development/test account. So one thought was that the specific account would be another extracted layer of directories, either a level above or below the env directory
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@kj22594 take a look here, similar conversation https://sweetops.slack.com/archives/CB6GHNLG0/p1569261528160800
Hi guys,
Any of you has experience with maintenance of SaaS environments? What I mean is some dev, test, prod environments separate for every Customer?
In my case, those environments are very similar, at least the core part, which includes, vnet, web apps in Azure, VM, storage… All those components are currently written as modules, but what I’m thinking about is to create one more module on top of it, called e.g. myplatform-core
. The reason why I want to do that is instead of copying and pasting puzzles of modules between environments, I could simply create env just by creating/importing my myplatform-core
module and passing some vars like name, location, some scaling properties.
Any thoughts about it, is it good or bad idea in your opinion?
I appreciate your input.
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
thanks. I’ll take a look
Hi guys,
Any of you has experience with maintenance of SaaS environments? What I mean is some dev, test, prod environments separate for every Customer?
In my case, those environments are very similar, at least the core part, which includes, vnet, web apps in Azure, VM, storage… All those components are currently written as modules, but what I’m thinking about is to create one more module on top of it, called e.g. myplatform-core
. The reason why I want to do that is instead of copying and pasting puzzles of modules between environments, I could simply create env just by creating/importing my myplatform-core
module and passing some vars like name, location, some scaling properties.
Any thoughts about it, is it good or bad idea in your opinion?
I appreciate your input.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in short, we use the following:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Terraform modules to provision resources on AWS https://github.com/cloudposse?utf8=%E2%9C%93&q=terraform&type=&language=
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- A catalog of top-level modules where we assemble the low-level modules together and connect them. They are completely identity-less and could be deployed in any AWS account in any region https://github.com/cloudposse/terraform-root-modules/tree/master/aws
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- A container (
geodesic
https://github.com/cloudposse/geodesic( with all the tools required to provision cloud infrastructure
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Then, for a specific AWS account and specific region, we create a repo and Docker container, e.g. https://github.com/cloudposse/testing.cloudposse.co
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it provides:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
1) all the tools to provision infrastructure
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
2) Settings and configs for a specific environment (account, region, stage/env, et.) NOTE that secrets are read from ENV vars or SSM using chamber
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
3) The required TF code for each module that needs to be provisioned in that account/region gets loaded dynamically https://github.com/cloudposse/testing.cloudposse.co/blob/master/conf/eks/.envrc
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
4) to login to AWS, an AIM role gets assumed in the container (we use aws-vault
)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so once inside that particular container (testing.cloudposse.co), you have all the tools, all required TF code, and all the settings/configs (that specify where and how the modules get provisioned)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so the code (logic) is separated from data (configs) and the tools (geodesic
), but get combined in a container for a particular environment
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
Wow, thanks. That makes a ton of sense and seems to be a very sound way of approaching this problem. I do really like the idea of having root level modules repo where you can interconnect different modules for use cases that happen numerous times but also having the modules split out so that they can be reused separately too
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also, while terragrunt helps you to organize your code and settings, this approach gives you much more -code/settings/tools in one container related to a particular environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(terragrunt still can be used to organize the code if needed) https://www.reddit.com/r/Terraform/comments/afznb2/terraform_without_wrappers_is_awesome/
One of the biggest pains with terraform is that it’s not totally 12-factor compliant (III. Config). That is,…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the nice part about all of that is that the same container could be used from three different places: developer machine, CI/CD pipelines (those that understand containers like Codefresh or GitHub Actions), and even from GitHub itself using atlantis
(which is running inside geodesic
container) - that’s how we do deployment and testing of our modules on real AWS infrastructure
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
That is really cool. Atlantis is something that I’ve had conversations with a friend about but we’ve never actually implemented it or even tested it
data:image/s3,"s3://crabby-images/d8b7c/d8b7cf189feaa194e0c2e89984c42d661d75cfe1" alt="kj22594 avatar"
I really appreciate this, this is all great knowledge and insight
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
public #office-hours starting now! join us to talk shop https://zoom.us/j/508587304
data:image/s3,"s3://crabby-images/a9fa6/a9fa6c642c2cffbe20ec9a71522b08dac940c5da" alt="party_parrot"
2019-09-26
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
Hey does anyone have a terraform party slackmoji?
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
I will trade you one terraform-unicorn-dab slackmoji.
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
lol
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
I’d love a terraform-parrot
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
hahaha
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
I was hoping for something like my kubernetes party:
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
I stole that form kubernetes.slack.com
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
Nice!
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
I just made it!
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
Probably not my best work, but not bad for a first gif
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
¯_(ツ)_/¯
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
Thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Niiice!
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Where do I get that unicorn XD
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
I really need it in my workspace
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
1) download the icons above
2) go here https://$[team.slack.com/customize/emoji](http://team.slack.com/customize/emoji)
where $team
is your slack team
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
XD
2019-09-27
data:image/s3,"s3://crabby-images/f900a/f900abd5f08cd1e6fe27a8f95d5ea1f49fcc82a2" alt="Rajesh Babu Gangula avatar"
@here I am trying to upgrade from v.11.14 to v.12 and after going through the upgrade steps and fixing some code changes … now I am seeing following issue
Error: Missing resource instance key
on .terraform/modules/public_subnets.public_label/outputs.tf line 29, in output "tags":
29: "Stage", "${null_resource.default.triggers.stage}"
Because null_resource.default has "count" set, its attributes must be accessed
on specific instances.
For example, to correlate with indices of a referring resource, use:
null_resource.default[count.index]
did anyone faced similar issue and was able to fix it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
try "${join("", null_resource.default..*.triggers.stage}"
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
Hi
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
I would apreciate some help with the terraform-aws-elasticsearch module
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
when trying to use it from the complete example
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
i get in a plan the following
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
tha’s one example but i get that for all the variables
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you have to provide values for all variables
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
it seems as if it were not reading the set variables
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
yeah, but in the variables.tf file?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or to use the .tfvar
files, use :
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
terraform plan -var-file="fixtures.us-west-1.tfvars"
terraform apply -var-file="fixtures.us-west-1.tfvars"
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
hoooo i see
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but don’t use out values
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
change them
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
so the modules as module "elasticsearch" { blah blah
should be empty of values if i use a tfvars file rigth ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can provide values for the vars from many diff places https://www.terraform.io/docs/configuration/variables.html
Input variables are parameters for Terraform modules. This page covers configuration syntax for variables.
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
how do you provide credentials to private terraform github repository module ?
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
like this in your providers.tf
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
then just set in variables.tf files the values
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
thanks
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
and how do i provide the path to github module if it is not at the root level
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
for example, source = "[email protected]:hashicorp/example.git"
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
but my main.tf is under modules
directory
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
@AgustínGonzalezNicolini how would i access it ?
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
[email protected]:hashicorp/example.git//myfolder?ref=tags/x.y.z
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
thanks
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
Thanks @Andriy Knysh (Cloud Posse)!!!
2019-09-29
data:image/s3,"s3://crabby-images/0f65e/0f65ea2592af59f1b2b9d017c2954c8559e16a0f" alt="Bruce avatar"
Hey guys, I am looking for the best way to roll back a change to an ASG to the previous known working ami as part of CICD pipeline with Terraform. Thinking of using a script to tag the previous AMI and using that to identify last known config. Has anyone else solved this problem?
data:image/s3,"s3://crabby-images/3c547/3c54718d528a1cd5e01420b9e569bdf089661131" alt="roth.andy avatar"
I’ve been asked to provision 3 EKS clusters: Dev, Staging, and Prod. What is the way that you guys do this? Currently, I’m thinking of
- Having 3 branches in my git repo called “dev”, “staging”, and “prod”
- Having 3
.tfvars
files calleddev.tfvars
,staging.tfvars
,prod.tfvars
- If I commit to
dev
, My CICD runsterraform apply
using a workspace calleddev
, usingdev.tfvars
data:image/s3,"s3://crabby-images/21b14/21b1448f806ed0ce1c929c6147f8e65119dcebda" alt="Nikola Velkovski avatar"
Hi @roth.andy, personally I am a fan of workspaces. We used to have to have this setup but without the fixed branches, CI/CD automaticaly deployed a branch to staging and for prod it was a interactive apply ( if tests passed )
2019-09-30
data:image/s3,"s3://crabby-images/004c6/004c63b2ee6db0afba1d838c774a94adb216bb2e" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Oct 09, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Guys, i’ve been using https://github.com/cloudposse/terraform-aws-vpc-peering to peer two vpcs and it works awesome. On current project I need to peer N numbers of VPC’s all with each other. As number of VPCs grows it become pretty hard to manage everything even with terraform. Is there any way to dynamically create peering mesh? CIDRs are carefully chosen so there will be no overlapping and I can fetch all vpcs with single data source. This shot from AWS describes my setup perfectly
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
I’d suggest using transit gateway
data:image/s3,"s3://crabby-images/269b3/269b3e6e20b633ab7b9517cc0f949d666ec0602b" alt="AgustínGonzalezNicolini avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you can now use share vpcs : https://docs.aws.amazon.com/vpc/latest/userguide/vpc-sharing.html
VPC sharing allows multiple AWS accounts to create their application resources, such as Amazon EC2 instances, Amazon Relational Database Service (RDS) databases, Amazon Redshift clusters, and AWS Lambda functions, into shared, centrally-managed Amazon Virtual Private Clouds (VPCs). In this model, the account that owns the VPC (owner) shares one or more subnets with other accounts (participants) that belong to the same organization from AWS Organizations. After a subnet is shared, the participants can view, create, modify, and delete their application resources in the subnets shared with them. Participants cannot view, modify, or delete resources that belong to other participants or the VPC owner.
data:image/s3,"s3://crabby-images/c0e5b/c0e5bf81bcad1146a092ca42ca02f48a1edab3e4" alt="Stephane Minisini avatar"
@Milos Backonja I would look into Transit Gateway. This allows you to have a hub and spoke type of network and manage the routing tables centrally.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
second this
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Awesome, thanks a lot, This simplifies my setup enormously. I will need to check/estimate costs.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you can do a bunch of other cool things with transit gateways, like centralize nat gateways, or hook in a central direct connect
data:image/s3,"s3://crabby-images/5108e/5108e52407799dcbc4bd8caaeaf6c8d9c53901b2" alt="rbadillo avatar"
Hi Guys, does anyone here using Terraform Enterprise ?
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Hub n’ Spoke with VPC Transit Gateway
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
does anyone know how to add private subnets to the default vpc using terraform?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Don’t use the default pvc, it is bad practice…
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
is there a module that creates a vpc with private subnet?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes, just go to clousposse github and search for vpc and subnets
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we use their modules and they work great
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @jose.amengual
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Brij S take a look at this example https://github.com/cloudposse/terraform-aws-emr-cluster/blob/master/examples/complete/main.tf
Terraform module to provision an Elastic MapReduce (EMR) cluster on AWS - cloudposse/terraform-aws-emr-cluster
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
specifically lines 5-24, right?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
does aws_alb_listener
resource multiple certificate_arn
?
data:image/s3,"s3://crabby-images/c2201/c2201476991e735b5c763fe1a9084a6283633786" alt="rohit avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
For those interested in the EKS modules, we’ve converted them to TF 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
For those interested in the EKS modules, we’ve converted them to TF 0.12:
https://github.com/cloudposse/terraform-aws-ec2-autoscale-group https://github.com/cloudposse/terraform-aws-eks-workers https://github.com/cloudposse/terraform-aws-eks-cluster/releases/tag/0.5.0