#terraform (2018-08)
Discussions related to Terraform or Terraform Modules
Archive: https://archive.sweetops.com/terraform/
2018-08-01
data:image/s3,"s3://crabby-images/13102/13102182b7d2346a906c367cd0533e8280ca1385" alt="pmuller avatar"
wow, thanks, those projects look great!
data:image/s3,"s3://crabby-images/13102/13102182b7d2346a906c367cd0533e8280ca1385" alt="pmuller avatar"
something related I would like to implement: https://github.com/mozilla-services/pytest-services
pytest-services - Unit testing framework for test driven security of AWS configurations, and more.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hi @pmuller
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for security testing on AWS, take a look at this tool https://github.com/dowjones/hammer
hammer - Dow Jones Hammer : Protect the cloud with the power of the cloud(AWS)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/21b9d/21b9d6b790c365fd0e5041aaede17510d3703fbb" alt="attachment image"
The new tool, called Hammer, was developed partly in response to the growing need for automation amid talent shortages and the fast-paced nature of software development, said Dow Jones CISO Jaswinder Hayre.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
so im looking at terraform-aws-s3-log-storage module. looks awesome. Here’s a loaded question.. I’ve a got a custom elastic beanstalk platform, using your terraform-aws-elasticbeanstalk module..
Is there a way you’d recommend to make that bucket name exposed to eb instances? (not manually).
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrmm… so basically, how to pass the bucket name from the log storage module to the beanstalk module?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
I think I’ll be using fluentd to push logs, and I’ve ran into a bit of head scratcher, the config file for td-agent doesn’t support environmental vars so
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
td-agent
~ fluentd?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yes
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
just a non-gem version
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok, so taking a further step back
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you’re running fluentd on the beanstalk instances to forward logs
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yep
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok, gotcha. sec
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ok, so the tf-agent
config should get parameterized
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We typically use gomplate
for that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then using gomplate
, you can consume env variables
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then pass the bucket name as an env to the beanstalk
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
I haven’t completely settled on fluentd. but it leaves a bit of flexibility instead of marrying to data firehose..
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hm
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
gomplate documentation
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
okay that just looks like magic
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
lol
2018-08-02
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hey, cloudposse/terraform-aws-cloudwatch-logs in description says … for use with fluentd. Do you guys have an example of how you use it with fluentd?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We use it with Kubernetes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I can share how we do that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hey @Ziad Hilal! Glad you signed up
data:image/s3,"s3://crabby-images/67a87/67a87c3dfb2c1aa3754543d770dcf9de3b7ae5a7" alt="Ziad Hilal avatar"
@Ziad Hilal has joined the channel
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Not Terraform, but .. should be here I think.. I had a fight with a daemon which was running inside a wrapper. It is sidekiq, and it’s important that sidekiq receives the SIGTERM. The wrapper script was necessary as it does a few other things.
Having this inside the dispatch.sh
SIDEKIQ_COUNT=3 SIDEKIQ_MAXMEM_MB=2000 SIDEKIQ_PRELOAD=sidekiq_swarm exec sidekiqswarm -t 25 -C config/sidekiq.yml
is not enough as it would still be a child of the entrypoint.
So in the Dockerfile this is what did the trick.
CMD exec /$APP_DIR/bin/dispatch.sh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@maarten was that meant for this channel?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
yeah,.. I just wanted to share something others might stumble upon at one moment.. Unsuited ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Oh, just maybe don’t get the full context.
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"
Aha, adding the exec
part
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
exactly.. on 2 places
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so basically, it’s running /bin/sh -c 'exec /$APP_DIR/bin/dispatch.sh'
, which then replaces PID1
with dispatch.sh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I’ve also run into problems with signal handling and shell scripts with docker.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and then inside dispatch sidekiq replaces it
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
we can also have a docker channel
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
haha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, probably a good idea.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I’ll remove my stuff here then
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#docker created
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s fine - we’ll start new ones there.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2018-08-03
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hey so for terraform-aws-elasticsearch module. its saying that EBS storage must be selected for t2.small.elasticsearch.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
is that not what’s used by default?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i’m gonna do more research into ES for now
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
well apparently i fail it setting up ES from this tf module. i’ve got a route53 domain, that all worked, the vpc endpoint is in public subnets.. but I cannot access ES or Kibana endpoints at all.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
and security group allows all traffic from 0.0.0.0/0
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you deployed it in the public subnets and opened up the security groups?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i believe so. I’ve just added the default security group just to try. will see if that helps
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i have iam access policy configured. im thinking thats the issue
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terraform-root-modules - Collection of Terraform root module invocations for provisioning reference architectures
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
here’s an example of how andriy deployed it
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
tnx
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
might be a dump question. but what is the purpose of this:
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
in terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It’s part of this horible/nasty hack to make it easy to pass envs
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terraform-aws-elastic-beanstalk-environment - Terraform module to provision an AWS Elastic Beanstalk Environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
perhaps there’s a better way of doing it now adays in HCL
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We had a more elegant way using null_resource
, but it would lead to frequent errors like cannot compute count of dynamic variable (or something like that)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So basically, the module always defines N fixed environment variables
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If the user provides it, it uses it, other wise you see something like DEFAULT_ENV_20=UNSET
in your beanstalk environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(which is just a place holder)
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
odd
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
I was looking at an existing platform. I wonder why they’re not showing how to use their container config in examples.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
with a custom platform, they just say here, specify :environment settings, and bam you got a platform. but then for example, looking at Ruby / passenger platform they have :container config as well, with nicely defined json for settings and what not.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What Changed the way the custom ENV vars are calculated in awsapplication:environment setting Why Using null_resource to generate key/value pairs for ENV vars like this: resou…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Here is more context
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What Fix element() for empty list workaround Fix key-value association Why For empty env_vars there was error element() may not be used with an empty list in: hashicorp/terraform#9858 keys() ret…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@pmuller I still think we should consider this//github.com/cloudposse/terraform-aws-rds-cluster/issues/26>
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It would be a nice security enhancement
data:image/s3,"s3://crabby-images/13102/13102182b7d2346a906c367cd0533e8280ca1385" alt="pmuller avatar"
hehe, love this approach!
data:image/s3,"s3://crabby-images/13102/13102182b7d2346a906c367cd0533e8280ca1385" alt="pmuller avatar"
did someone tried https://github.com/juliosueiras/vim-terraform-completion ?
vim-terraform-completion - A (Neo)Vim Autocompletion and linter for Terraform, a HashiCorp tool
2018-08-06
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What Add an option to use a sub-provider for roles, so they can be created in a different account than the users who can assume it. Why We have a use-case where we need admin and readonly roles in …
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
any opinions on taking this approach?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@sarkis @Andriy Knysh (Cloud Posse)
2018-08-07
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
please see my comments on that: https://github.com/cloudposse/terraform-aws-iam-assumed-roles/pull/7#issuecomment-411117761
What Add an option to use a sub-provider for roles, so they can be created in a different account than the users who can assume it. Why We have a use-case where we need admin and readonly roles in …
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jamie shouldn’t we be using a label here? https://github.com/cloudposse/terraform-aws-efs-cloudwatch-sns-alarms/blob/master/alarms.tf#L13
terraform-aws-efs-cloudwatch-sns-alarms - Terraform module that configures CloudWatch SNS alerts for EFS
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Yes
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ok, I’ll log an issue
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
All of the modules need to have a revision to handle context
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
how are you doing man?
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Exhausted!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
from vacation?
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Yeah
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Way behind from vacation so playing hard catchup
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
My ticket is up tomorrow! Tulum, MX
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@jamie some of your changes to terraform-null-label
do not respect the enabled
flag. So when I test it with var.enabled=false
, Terraform still wants to recreate some resources
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you change the module, you might want to take a look at that too
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
I will address that. Sorry that should have been picked up at review. But it was pushed through quickly.
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Thank you for testing.
2018-08-08
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
I’m trying to figure out how to use https://github.com/cloudposse/terraform-aws-rds-cloudwatch-sns-alarms with https://github.com/cloudposse/terraform-aws-sns-lambda-notify-slack am I missing something obvious?
terraform-aws-rds-cloudwatch-sns-alarms - Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic
terraform-aws-sns-lambda-notify-slack - Terraform module to provision a lambda function that subscribes to SNS and notifies to Slack.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jamie can maybe provide an example for this. I am afk this week. @sarkis also might have a similar example ready that we are using for ECS.
terraform-aws-rds-cloudwatch-sns-alarms - Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic
terraform-aws-sns-lambda-notify-slack - Terraform module to provision a lambda function that subscribes to SNS and notifies to Slack.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
Thank you
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
https://github.com/cloudposse/terraform-aws-ecs-cloudwatch-sns-alarms appears to take the SNS as a parameter
terraform-aws-ecs-cloudwatch-sns-alarms - Terraform module to create CloudWatch Alarms on ECS Service level metrics.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
That would work with the slack tf then.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Great! Hope that unblocks you.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Put a TODO for myself to get some better example in the repos for how they work together..
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
ah, I think I see! You can provide a topic name to the slack integration to use, and set create_sns_topic to false. That’s not super clean, as you end up with a lambda per sns topic, and if I need one for each module of alarms I use (i.e. one per rds, one per asg) that’s going to rack up a count very quickly.
It would be nice if they composed.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform as a language is pretty limited. To reduce complexity of of an individual module we like to keep them logically separated. This reduces the scope and easier to test. We also like to think this makes them even more composable. Users can mix and match as they see fit without being overly opinionated.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
For example, look at our ecs web app module. This is a great example of how many modules are composed to implement a powerful opinionated module.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
In this case I think the problem is that the slack lambda expects a one-to-one mapping, and reality is a many-to-one. It should take a list of sns topics to subscribe to.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
If you want to extend it, we’ll prompt review the the PR :-)
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
Thinking about it. Part of the problem is that Cloudposse is delegating to another terraform module altogether. So that would mean taking maintenance of that module.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That other module is by @antonbabenko
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Check with him - he maintains a lot of great modules and would probably accept the PR or provide insights
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jamie started a Cloudposse slack notification module, but don’t think he has had the time to finish it.
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Where is my sense of completion
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
I’ll get to sorting that tomorrow for you!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Haha you certainly set off on an ambitious path. Think you wrote (or started) like 20 modules in a month.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
I suspect policies are part of all this, but I’m not sure. Policies in AWS don’t ever compose nicely, you end up centralizing your SNS because you need an RDS policy and you can’t just append that to an existing one. I feel like Terraform should let you “append” to resources defined elsewhere, but that’s a very hard set of constraints to match I accept.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
yeah, that’s it. The RDS module creates it’s own SNS topic because it doesn’t just do CloudWatch it also configures RDS event notifications to the topic. This means the policy isn’t just CloudWatch, but CloudWatch + RDS. (Although the description is wrong - typo-level PR incoming)
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
:wave: Hello! :slightly_smiling_face: I’m attempting to use terraform-aws-cloudtrail
for the first time and just hitting an issue with the event_selector
. It defaults to {}
but this causes aws_cloudtrail
to create an event selector anyway.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
We then get this on every apply
:
~ module.cloudtrail.module.cloudtrail.aws_cloudtrail.default
event_selector.#: "0" => "1"
event_selector.0.include_management_events: "" => "true"
event_selector.0.read_write_type: "" => "All"
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Removing the event_selector
variable/parameter from terraform-aws-cloudtrail
‘fixes’ the issue.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Looks like null
/ undefined parameters will be coming in HCL2 but until then I’m not sure what the answer is.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrmmm I am not sure off the top of my head. @Andriy Knysh (Cloud Posse) might have some suggestions. He originally implemented it.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
@antonbabenko has joined the channel
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hi @paul, give me some time, I’ll look into terraform-aws-cloudtrail
event_selector
. You can open a PR with your fixes so it’d be easier to review and test
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
@Andriy Knysh (Cloud Posse) :wave: At the moment I don’t have a fix, other than commenting out the event_selector
. We’re discussing it internally at the moment, if we think of a neat way around it then I’ll PR it.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
@Andriy Knysh (Cloud Posse) @paul out of curiosity, does the string ""
work as blank? Or maybe doing event_selector = []
?
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
I’ll give it a go, let’s find out.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Actually, the variable type is set to a ~map~ist.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
hehe I hit something similar this morning.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
of maps.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Giving it a go.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
Yep. It’s the same for launch_configuration root_block_device, for no particular reason, perhaps for nicer syntax as:
event_selector {
…
}
Rather than
event_select = {
…
}
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
tbh, the pain of this goes away with terraform 12 if you can wait, now that conditionals can return lists you can do:
event_selector = "${var.event_selector == {} ? [] : [var.event_selector]}"
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
https://github.com/hashicorp/terraform/issues/12453#issuecomment-327266951 you could try this though if you’re a masochist.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
(Basically join the k/vs of the event_selector with a separator, and then split it outside the conditional)
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
So if I do this..
variable "event_selector" {
type = "list"
description = "Specifies an event selector for enabling data event logging. See: <https://www.terraform.io/docs/providers/aws/r/cloudtrail.html> for details on this map variable"
default = []
}
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
It then works correctly.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
It would then require people to supply a list of maps though, so it wouldn’t be backwards compatible.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
I think.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
You could also do that, which is what I decided to do internally. However, I think that changes usage slightly. It might be as simple as changing event_selector = {}
to event_selector { }
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Where would I make that change?
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
when using the module, that would be, so still a breaking change.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Ah.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Fiddling with different combinations.
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
Anyone have experience deploying AWS AD service with terraform?(includes creating vpc, subnets, jumpboxes etc)
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
bah. No joy.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
A map() function would make this so much easier (in the fp sense), as you could use compact & map.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
@paul how about slice(list(var.event_selector), 0, length(var.event_selector) > 0 ? 1 : 0)
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
that took way too much fiddling to discover. Nice trick once you know it though
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Oh, interesting. I’ll give that a try later this evening. (BST timezone)
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Thanks.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
Fellow brit?
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@paul @dominic so I tested this example https://github.com/cloudposse/terraform-aws-cloudtrail/blob/master/examples/complete/main.tf
terraform-aws-cloudtrail - Terraform module to provision an AWS CloudTrail and an encrypted S3 bucket with versioning to store CloudTrail logs
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when event_selector = []
(empty list), Terraform never tries to recreate resources
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if we put a map inside a list, it always tries to recreate regardless if the map is empty or populated
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
event_selector = [{}]
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
event_selector = [{
read_write_type = "All"
include_management_events = true
}]
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in both cases
~ module.cloudtrail.aws_cloudtrail.default
event_selector.#: "0" => "1"
event_selector.0.include_management_events: "" => "true"
event_selector.0.read_write_type: "" => "All"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
looks like a feature/bug
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also in the docs, it does not mention at all that event_selector
should be a list, it looks like a map
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Provides a CloudTrail resource.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we can change it to
variable "event_selector" {
type = "list"
description = "Specifies an event selector for enabling data event logging. See: <https://www.terraform.io/docs/providers/aws/r/cloudtrail.html> for details on this map variable"
default = []
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which will silence it in the case when we don’t need any event selectors
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but will not help in other cases
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@jamie any ideas on that?
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
@Andriy Knysh (Cloud Posse) I think we can have the best of both worlds using the slice()
trick above. The other being that we don’t break backwards compatibility.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
don’t worry about backwards compatibility, we use tags in all modules like here https://github.com/cloudposse/terraform-root-modules/blob/master/aws/cloudtrail/main.tf#L34
terraform-root-modules - Collection of Terraform root module invocations for provisioning reference architectures
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so if we need to update to the new version, we update the tag and update the top-level module
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
I think backwards compatibility is always important, regardless of pinned versions. I imagine this is something that differs across programming communities. I also think the current interface is the most idiomatic.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
@jamie Regarding SNS, RDS etc. I just after much hacking around terraform, managed to create a “terraform-sns-claims”. Essentially modules like the RDS alarms module export a variable of claims with a value like ["cloudwatch", "rds"]
. Internally, the sns module stores a statement relating to that claim. It then generates a policy from the set of claims. I need to find out if anything else actually pushes to SNS (e.g. autoscaling events perhaps), but this is a fairly tidy system for allowing the sns policy to be dictated by the alarms you want.
If you’re hacking on the slack sns stuff tomorrow, I can probably publish my SNS work, and you can bring it into cloudposse if you wish (whatever license I need to use, I will). I’d love to not have to fork slack too I’ll probably look into contributing RDS event support at the same time.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Thanks @dominic ! Definitely ping feel free to ping me directly as well
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Both @jamie @Andriy Knysh (Cloud Posse) @Igor Rodionov and @maarten can create repos under the Cloud Posse org.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Generally, we use the APACHE2
license. Just copy it from any one of our other repos.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
Will do Of course it’s dependent on you guys liking the approach, my thinking it has merit means little
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
I’ll do it tomorrow then. Please push any suggestions you want and I’ll merge them as needed! Please and thank you!
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Apologies, I didn’t get chance to try out the suggested solutions this evening. It’s in my diary for the morning.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
I think I’m leaning towards the changing to a list solution. It’s far cleaner solution than slicing and the AWS provider is expecting a list anyway.
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
@jamie references for the gh repos:
https://github.com/SevereOverfl0w/terraform-aws-rds-cloudwatch-sns-alarms https://github.com/SevereOverfl0w/terraform-aws-sns-claims
Usage example for both found in the rds repo.
terraform-aws-rds-cloudwatch-sns-alarms - Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic
terraform-aws-sns-claims - Create an SNS topic based on a list of claims
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
https://github.com/cloudposse/terraform-aws-cloudtrail-cloudwatch-alarms/blob/master/main.tf#L8 might be a better approach overall, uncertain of how multiple policies apply to an sns.
terraform-aws-cloudtrail-cloudwatch-alarms - Terraform module for creating alarms for tracking important changes and occurances from cloudtrail.
2018-08-09
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
@jamie I ended up forking the slack lambda, https://github.com/SevereOverfl0w/terraform-aws-notify-slack it’s not really in a pull-requestable state, but if you’re hacking on this it might serve as inspiration.
terraform-aws-notify-slack - Terraform module which creates SNS topic and Lambda function which sends notifications to Slack
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Thank you
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
I’m on them now
data:image/s3,"s3://crabby-images/6e06a/6e06a0e4157eff9167505446e5d8974896126b72" alt="dominic avatar"
I’m now onto monitoring our autoscaling groups I see you’re also responsible for ec2
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
FYI team, this environment variable isn;t in the documentation last time i checked, but can get you around some annoying errors when destroying resources.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Thanks, I’ve added an inssue to document this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what This environment variable isn't in the documentation, but can get you around some annoying errors when destroying resources. export TF_WARN_OUTPUT_ERRORS=1 why It converts the errors that …
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
export TF_WARN_OUTPUT_ERRORS=1
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
It converts the errors that would normally halt the destruction of resources from a module
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
into warnings
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
and therefore allows you to complete the destruction of a TF template
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
For terraformers, who like dirty hacks, and who are encountering issues with count.index inside a conditionally created resource with count to length(var.of_a_list).. here’s something that worked for me
create a data “template_file” with count of the length of the list with no conditions.
data "template_file" "custom_listen_host" {
count = "${length(var.custom_listen_hosts)}"
...
And refer to the template_file from the resource with the condition..
resource "aws_lb_listener_rule"
"host_based_routing_custom_listen_host" {
....
count = "${local.create && length(var.custom_listen_hosts) > 0 ? length(var.custom_listen_hosts) : 0 }"
values = ["${data.template_file.custom_listen_host.*.rendered[count.index]}"]
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @maarten for the example
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Until 0.12 is there, everything is allowed I thought @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not every hack I guess, but if it looks good, why not
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this count = "${local.create && length(var.custom_listen_hosts) > 0 ? length(var.custom_listen_hosts) : 0 }"
could be simplified to count = "${local.create ? length(var.custom_listen_hosts) : 0 }"
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
hey, that’s true
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@paul
I think I’m leaning towards the changing to a list solution. It’s far cleaner solution than slicing and the AWS provider is expecting a list anyway
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
want to test and open a PR?
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
Yeah, happy to give that a go tomorrow afternoon. Off the clock now
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
perfect
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i tested it a little bit https://sweetops.slack.com/archives/CB6GHNLG0/p1533750657000315
@paul @dominic so I tested this example https://github.com/cloudposse/terraform-aws-cloudtrail/blob/master/examples/complete/main.tf
data:image/s3,"s3://crabby-images/8ad84/8ad8467ee1d68c21018c61756a5e58372042200e" alt="Igor Rodionov avatar"
@Igor Rodionov has joined the channel
2018-08-10
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
I spent a bit of time on the issue with event_selector
this afternoon but haven’t got it working for all use cases (no event_selectors, a single event selector, multiple event selectors). I’m going to return to it towards the end of next week.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @paul
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(agree, not easy to make it working in all cases)
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
No problem. I found lots of github issues around Terraform asking for it to support exactly this kind of thing but no concrete solutions have materialised.
data:image/s3,"s3://crabby-images/e396d/e396dff9a1705ec8d9f0170fb475bc1d7ea2ac0c" alt="paul avatar"
I’m going to see if I can get a colleague or two of mine to have a look next week to see if we can think of a way around it.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hi again
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
I’ve just ran into a head-scratcher issue with terraform..beanstalk module i think.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
I’ve got 5 environments. it created 4. but this last one its got this issue. and I can’t figure out for the life of me where its picking up “elb-logs-makeshift” bucket name from.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
in the main.tf of the module, this is the only reference:
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that’s really odd! haven’t seen elb-logs-makeshift
before. I grepped through all of our modules and don’t see it and it doesn’t appear in any of our code. https://github.com/search?q=org%3Acloudposse+makeshift&type=Code
GitHub is where people build software. More than 28 million people use GitHub to discover, fork, and contribute to over 85 million projects.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
ikr
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
and terraform plan, grepped for elb, also doesn’t produce it.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what about your ENV?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
export | grep makeshift
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
makeshift is a known name. but “elb-logs-makeshift” in that combination is not
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
uhm
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
export locally yes, but that’d affect other environments tho..
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in this case, looks like namespace=elb
, stage=logs
, name=makeshift
(if you’re using our label module)
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
not explicitly no. just using your beanstalk environment module
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ok
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
we had this environment up before too. this is so bizarre. we used an older module, and im now rewriting with the new one. but then even in your module, the way you define it, it’d be elb-logs ending.. not elb-logs+string
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
#killmenow
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, makes no sense. must be some silly error somewhere.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
this has to be some bug with aws or something. because the rest of the environments just use a normal elb-logs-<random_digits> s3 bucket.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
Don’t think i like EB anymore. So high maintenance
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
And very slow to iterate
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i’d ask amazon but don’t have support subscription yet
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
and funny thing is, aws cli says that s3 bucket doesn’t exist.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
but when trying to create it, it says “$ aws s3 mb <s3://elb-logs-makeshift> makeshift2.3.7 make_bucket failed: <s3://elb-logs-makeshift> An error occurred (BucketAlreadyExists) when calling the CreateBucket operation: The requested bucket name is not available. The bucket namespace is shared by all users of the system. Please select a different name and try again.”
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
“$ aws s3 ls elb-logs-makeshift makeshift2.3.7
An error occurred (NoSuchBucket) when calling the ListObjects operation: The specified bucket does not exist”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh, maybe someone else on AWS owns that bucket.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that would explain why you cannot list it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@i5okie we suggest using label
or a similar naming pattern for consistency and to eliminate naming contention
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, all buckets are global
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
except when you do aws s3 ls
, it shows only your account
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yeah that makes sense.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you said elb-logs-<randomstring>
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
could makeshift
be generated as one of the random strings ?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
but why would it try to create/use a bucket that nothing asked it to use. and the other environments created with the exact same module and config essentially, just use the standard elb-logs-3434343434 thing that aws picks by default.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
no, because other environments go into elb-logs-<randomdigits>
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
the same one
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
without that being explicitly specified anywhere in the config files.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
oh i see. its actually elb-logs-<accountnumber>
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
just use this https://github.com/cloudposse/terraform-null-label
terraform-null-label - Terraform Module to define a consistent naming convention by (namespace, stage, name, [attributes])
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
terraform-terraform-label - Terraform Module to define a consistent naming convention by (namespace, stage, name, [attributes])
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
it makes no sense that from scratch I’ve just created other environments with this module and it went fine, and used the normal per-account elb-logs bucket. and this one odd-ball decides not to. I’m using this: https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment
terraform-aws-elastic-beanstalk-environment - Terraform module to provision an AWS Elastic Beanstalk Environment
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
for all of our environments.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
so why would i use label separetly?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not sure how it relates to the <accountnumber>
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
can you share your code?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
thats just what EB does naturally creates per-account elb-logs s3 bucket, and uses it for all environments. terraform no terraform, its just what it does
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
which code
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i have to use local copy of the module because to modify the healthchec url varriable a bit.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what’s the diff between those 5 envs? stage
?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
no. app names
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
5 applications, 3 stages each
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
but im only re-doing the staging env for now
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
which is in its own vpc, etc etc
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
so “name” variable would be different between the 5. plus app versions, and env vars.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
terraform plan, or apply output does not mention “elb-logs-makeshift”. in fact here’s a line
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the EB logs bucket get created here https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L965
terraform-aws-elastic-beanstalk-environment - Terraform module to provision an AWS Elastic Beanstalk Environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but @i5okie still, how all of this relates to what you said about elb-logs-<randomdigits>
?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what is randomdigits
here and where they from?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
its actually account number.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
ELB doesn’t use these buckets that are created.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
it ends up using the account-default elb-logs-<accountnumber> bucket instead.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
don’t know why
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s not in the image above
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
im thinking this is a bug at AWS side.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
because I could let you read all of my terraform files, and you wouldn’t find anything that would put the strings together to say “elb-logs-makeshift”
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
oh i have an idea. i’ll delete the .terraform folder and try again
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea try that
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
can you show all bucket names from the 5 env that EB created?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
there is in fact 5th one
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but where is randomdigits
in there?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
but they are all empty. and all elb logs go to the elb-logs-<accountnumber> bucket instead.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it should not add any random things
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
your module doesn’t
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
its just what elb does
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i think you have naming collision somewhere
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
we used an older module of yourse for this. all names were the same. in fact the only difference i noticed between the versions of modules is the order of names/namespace/stage is different.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
not that it matters
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
ok deleting terraform folder and re-starting didn’t help
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
and its lying
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
it did create the load balancer
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
but it quits on actions and doesn’t add instances
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i’ll have to wait an hour before the “(terminated)” envs dissapear from console, and create the env manually. then try to import it into the terraform.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@i5okie just to confirm. The bucket that terraform-aws-elastic-beanstalk-environment
creates, is for Load balancer logs https://docs.aws.amazon.com/elasticbeanstalk/latest/dg/command-options-general.html#command-options-general-elbv2
Configure globally available options for your Elastic Beanstalk environment.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they have the names as you showed in the images above
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
at the same time, EB creates a bucket per region where it stores all EB stuff (e.g. app versions)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and that bucket name looks like this elasticbeanstalk-us-east-1-<accountId>
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i have both
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s the only thing with Account ID
there
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i have the buckets that you specify in the terraform module for elb logs, the elb-logs-<accountnumber> bucket that elb spits elb logs into when i enable those. and the elastic-beanstalk-<region>-<accountnumber> buckets
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i don’t ask it to change which buckets to put logs into. i’m just going with what it does.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
it probably does it when i say to forward logs to cloudwatch
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
in web console
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
its aws
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
just created environment from scratch by manually on web console. same error.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hmm
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what’s the error?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
the reference shows up in cloudformation template
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
how it gets to that template, i have no friggin idea
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
im going to delete the stack and try creating it manually again
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea sounds like you need to delete everything first
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
which is odd. i deleted the environment, waited for it to disappear from the console, then manually created it. and it ran into the same error. I guess it kept the cloudformation stack template and kept trying to re-create the stack from template? so odd
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
ok, time for aws support. deleted environment. deleted cf template. applied terraform. same error
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can try to create a new EB application and deploy the env into it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(it’s actually a good idea to deploy each env into its own application)
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hmm
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
a new application for each stage?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hmm
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s better for many reasons
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Since each stage should be in a separate AWS account to ensure isolation.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Which then necessitates using a separate app.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yeah separate account makes sense
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for now each stage could/should be in a separate app
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
not using EB is probably also a good idea
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not really It’s good at what it does. Never seen the issues like you are having
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
no not like this. But the hours I’ve spent “trying” to make things work with EB.. i probably could have learned how to use ECS properly.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
maybe
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but EB is actually much simpler in many cases
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
true very much so
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
guess what
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
new application, manual environment setup in web console.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
same issue
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
lol. alright i’ll see what amazon says.
2018-08-13
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
wow. all the time i was pulling my hair out.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
just to find the “elb-logs-makeshift” in .ebextensions of the app code itself.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
well, glad you found the issue @i5okie
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
how the other 4 env were deployed? without ` .ebextensions`?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
different applications
2018-08-16
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Funny thing I just found out.
It is possible to chain aws_iam_policy_documents by taking the .json-output of one aws_iam_policy_document’s as input with the parameter source_json for another aws_iam_policy_document. This way it’s possible to conditionally add statements to a single policy. Context is that not all sources support multiple policies ecr_repo is one of them.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
yeah, it’s a great feature, but can still use some improvements, https://github.com/terraform-providers/terraform-provider-aws/issues/5047
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"
that’s a nice trick!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Anyone figured out how to add multiple principles using aws_iam_policy_document ?
principals {
identifiers = ["${var.allowed_read_principals}"]
type = "AWS"
}
gets rendered to this json:
“Principal”: {
“AWS”: “arniam:root”, “arn
iam:root”, “arn
iam:root”, “arn
iam:root”
}
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
nevermind, it’s something else, replacing var.allowed_read_principals with a self-made list does work
2018-08-17
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@maarten is var.allowed_read_principals
a list?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I should have deleted the question
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
no it was not in the end
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
all fixed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
2018-08-20
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Greetings. I’ve been testing out your beanstalk-environment module and I’ve been having the problem that every-time I run terraform it plans to change everything, even immediately after the initial environment creation etc.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
I haven’t updated anything or changed any values and from the output I’m seeing Terraform wants to change values from their current value to the exact same value.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
In some cases it’s removing a setting and then re-adding it later on
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
setting.3926968379.name: "" => "SSHSourceRestriction"
setting.3926968379.namespace: "" => "aws:autoscaling:launchconfiguration"
setting.3926968379.resource: "" => ""
setting.3926968379.value: "" => "tcp, 22, 22, 0.0.0.0/0"
setting.502734328.name: "SSHSourceRestriction" => ""
setting.502734328.namespace: "aws:autoscaling:launchconfiguration" => ""
setting.502734328.resource: "" => ""
setting.502734328.value: "tcp,22,22,0.0.0.0/0" => ""
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
in other cases it’s the below:
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
setting.3402994671.name: "Statistic" => "Statistic"
setting.3402994671.namespace: "aws:autoscaling:trigger" => "aws:autoscaling:trigger"
setting.3402994671.resource: "" => ""
setting.3402994671.value: "Average" => "Average"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrm… don’t believe that should be the case.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@i5okie are you seeing this behavior?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
also, what version of terraform and aws provider are you using?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andrew Jeffree please show the output from terraform init
and terraform plan
, and also the code how you instantiate the module
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for reference, this is how we deployed it before https://github.com/cloudposse/terraform-aws-jenkins/blob/master/main.tf#L14
terraform-aws-jenkins - Terraform module to build Docker image with Jenkins, save it to an ECR repo, and deploy to Elastic Beanstalk running Docker stack
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(although it probably was tested with older TF version)
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Sure gimme a min
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
So I think at least with the first snippet I pasted it’s an issue between how terraform provides the string to beanstalk and how beanstalk returns it.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
@Erik Osterman (Cloud Posse) I’m seeing terraform re-do almost every setting. Very similar behaviour to re-setting the Tags even if they were not changed.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
it doesn’t replace any environment, or instances. just the setting.xxxxxxxxx.xxxx stuff.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
using terraform 0.11.8
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrmmm my guess is it’s a regression in terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We didn’t see this behavior in earlier versions but sounds like it’s a problem now.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
It’s probably because maps in golang aren’t stable
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Stable in the sense they are not ordered the same between executions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I don’t know how to fix this but will gladly accept any PRs
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Haha
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Yeah I figure it’s either terraform or the beanstalk api.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
I’ve had to hassle AWS to fix a few bugs in the beanstalk api recently
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
so I wouldn’t be surprised if it has further issues.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
If I figure it out I’ll certainly submit a PR
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
Thanks for at least confirming I’m not going insane and missing something super obvious
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Ahhh yea…. you’re not going insane
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
not yet at least
2018-08-21
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
So for the ssm parameters piece. If I have the ssm stored in AWS and just want to pull that. Do i just use data AWS ssm parameters to get the keys?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pericdaniel after you store params in SSM, you can read their values from another TF module: https://github.com/cloudposse/terraform-aws-ssm-parameter-store#simple-read-parameter-example
terraform-aws-ssm-parameter-store - Terraform module to populate AWS Systems Manager (SSM) Parameter Store with values from Terraform. Works great with Chamber.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to know the names of the params when you write them and then when you read them from other modules
2018-08-22
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what Add new target to upgrade all module sources why Keep modules up to date demo Processing ./test/test.tf… [SKIPPED]: ../ Processing ./test/cloud-provider.tf… Processing ./examples/wordp…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@tamsky
what Add new target to upgrade all module sources why Keep modules up to date demo Processing ./test/test.tf… [SKIPPED]: ../ Processing ./test/cloud-provider.tf… Processing ./examples/wordp…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@sarkis want to turn this into a go app?
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Yes! Awesome work on this @tamsky /bow, I’d be able to get some time to get an initial commit at least this Sunday.
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
@sarkis I get zero credit for this PR – it was all Erik
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Well then Erik /bow
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Added make target to upgrade all terraform module sources to latest version
2018-08-23
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Based on discussion in dependabot/feedback#118.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@michal.matyjek @Daren
Based on discussion in dependabot/feedback#118.
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
that’s amazing – it’s merged already
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, he’s fast!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i’ve heard many-a-times a developer say “i have some free time, let me implement that today”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and 2 mo later it’s not done.
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
even more impressive is the non-trivial nature and volume of code. agree on all points
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea… i thought so too
2018-08-24
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Some nice modules here: https://github.com/devops-workflow
Full Automated, DevOps type, Workflow Project
2018-08-26
data:image/s3,"s3://crabby-images/fc58d/fc58dd1f29c6c5aa6747e7d9ee4a1db5df68ff23" alt="alex.somesan avatar"
@alex.somesan has joined the channel
2018-08-27
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Broad topic, but how are you guys handling multi account AWS deployments?
- Creds per account (interpolated somehow in CI)
- Cred with assume roles?
- some other?
Im just curious to see how others are doing this
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
we use assume role
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pecigonzalo we use separate AWS accounts per stage (prod, staging, dev) and also a separate account (we call it root
, although a better name might be identity
) where we provision all IAM users and roles. We then use roles to login to the member accounts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
take a look at our reference architectures https://docs.cloudposse.com/reference-architectures/
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
what @Andriy Knysh (Cloud Posse) said
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
the terraform provider looks something like this:
provider "aws" {
profile = "<profile with credential allowed to assume role>"
assume_role {
role_arn = "<role arn in target account>"
}
}
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
@Andriy Knysh (Cloud Posse) we use something similar for our users and assume roles for entering the accounts
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
but for CI I was unsure, we are going the way of per AWS Account->CI User
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think I saw this in the AWS reinvent talk
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"
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
so we are sure that we limit the scope of the blast
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
but at the end of the day we have to interpolate the correct CI User for each stage of the deployment
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
which is meh
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
oh, we are working on that now too
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
and CI has all users, so the blast could be really big
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we are going to assume roles with MFA by using this tool https://piotrkazmierczak.com/2016/mfa-tokens-in-your-terminal/
A personal blog.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I saw your [prod.name.com](http://prod.name.com)
[this.name.com](http://this.name.com)
structure for the AWS Accounts and think its great for the accounts, but I dont think it translates to app deployment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So each app corresponds to a stage
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
But you’re right app specific cicd does not belong in this repo
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
For that we use a build pipeline defined in each app repo
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We use Codefresh for cicd
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah, i was not asking so much about the tool, but more about the how do you pass different creds/etc for AWS app deployment, as you can see further on, I commented how we plan to do it
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"
we just added it to geodesic
https://github.com/cloudposse/geodesic/pull/248
what Install oath-toolkit why Easy build one-time password authentication systems (including for AWS with MFA) Required for Terraform CI/CD install Step 65/74 : RUN echo "http://dl-cdn.alp…
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Interesting
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
geodesic
is our container which we use to login to the accounts and provision resources
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yep
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we create a CI/CD user per stage (prod, staging, dev, etc) and then use oath-toolkit
to get the MFA token and then assume role
to login to the account
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
but doesnt generating the token on your computer defy the objective of MFA? as you have the MFA gen and AWS creds on the same place
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In any case, I believe that might be a different converesation
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea, it’s a long conversation
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
My original quesiton was more about, how do you deploy apps to the different environments with multiple AWS accounts
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Codefresh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We define a pipeline file in each codebase
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Then use staged Codefresh accounts. So a production account executed production pipelines
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
A staging account executed staging pipelines
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Staging account also executed production pipeline to preproduction account in staging environment so we get to test that too
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Different Codefresh accounts all together or different stages in the pipeline?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So with codefresh enterprise, we can create as many accounts as necessary, just like AWS accounts. So the idea is to use a different codefresh account for each aws account that needs CI/CD
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We can reuse the pipeline, or create new ones, but they are all stored in git
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we register the pipeline we want to use in the account that has the integrations
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so the production account will have integrations to production kubernetes cluster, production ECR, etc
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
while the staging account will only have integrations to the staging kubenretes cluster, and a pre-production ECR registry where we test the production pipeline, but in a staging context
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the key is the pipelines are reusable across accounts
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we can test/use them in any account
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
I did not know that was a feature of CF enterprise, interesting!
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
We do the same for pipelines, but I think having a complete separate account, where you can register separate integrations could be really interesting.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In any case, thanks for sharing!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
For sure… let me know if you’d like an introduction to someone over there.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We work a lot with them and I can vouch for their support being top notch.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(they also use slack)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ah, it’s easy let me show
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
In your case its Kube, so you have to pass the kube endpoint and creds for each env
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
depending on the branch or stage in the pipeline
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we have a collection of TF modules which we use for all stages/environments. The modules have no identity (you can say they are just templates) https://github.com/cloudposse/terraform-root-modules
Collection of Terraform root module invocations for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then in the geodesic
shell for a member account, we pull the resources we need
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
1 moment, that part I follow
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
As I follow your cloudposse project, thanks a lot btw for some of the ideas/concepts
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform/Kubernetes Reference Infrastructure for Cloud Posse Production Organization in AWS - cloudposse/prod.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Example Terraform/Kubernetes Reference Infrastructure for Cloud Posse Production Organization in AWS - cloudposse/prod.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no problem
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so the identity comes into play in the accounts repos
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which we use from geodesic
shells per account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and we store all credentials in AWS SSM and use chamber
to read them
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah we use a similar workflow for that part
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
with chamber
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
But those are a repo per env, so those are a bit different I guess.
After you have KOPS and you your PaaS in a way, lets say now you have app1
how do you deploy it?
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
EG: some people have a var set (all fake vars, just used as an example) KOPS_ENDPOINT KOPS_USER KOPS_PASS then on each stage of the pipeline, or branch depending on how you deploy, they interpolate the right values there.
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
even if they are on chamber, you have to store either 3 AWS accounts for chamber, or 1 AWS account for chamber, with multiple secrets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we use CodeFresh pipelines to deploy apps to k8s clusters
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and we use geodesic
which has ` chamber` inside
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in the pipelines (per account/stage) we read the ENV vars from SSM and CodeFresh applies them
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
so CodeFresh has permissions to access each SSM for each env?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Codefresh uses containers per step, so it’s easy to use geodesic
there
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Ah right
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
and you have the creds on each container
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Nice
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Thanks for your answer, It gave me some ideas
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you welcome. I believe @Erik Osterman (Cloud Posse) has a lot more to add to this
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
We are going a different way right now, we will a have a CI AWS Account, whith a CI chamber, that we can get the envs for each environment on each stage of the deploy
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
But was looking for alternatives/improvements
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
BTW Im trying to fix https://github.com/segmentio/chamber/pull/70 so it finally merges and we get per env/custom paths
This PR makes it possible to have the service have a variable depth for the service (<path>/<service>). The default "." separator is also supported e.g chamber write some/path…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
interesting
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since chamber
can accept multiple services when reading (e.g. chamber read service1 service2 key
) we use multiple services to override the default values (if needed)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
e.g. chamber read kops app1 db_password
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
Yeah, we use something like chamber exec ci-development ci-app1
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
But I want to have a cleaner SSM, as the interface sucks a bit
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
so having /devel/ci
or similar will be ideal
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
or something like /external/thisprovider
for any sahred keys we want to actually share
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
for CI of apps we are currently moving to something like:
(CI has CI AWS Account creds)
chamber exec aws-development --
(CI AWS Account is overwritten by Dev AWS Account)
chamber exec ci-app1 -- example command
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
aws-development
secret lives in CI Acccount
ci-app1
secret lives in Dev Account
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
That’s nice
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
We use the same secret names for all accounts since SSM is per account, and this way all our code remains the same
data:image/s3,"s3://crabby-images/aebf7/aebf7221e659846e45e8b74d68e7b58995ef6e8a" alt="pecigonzalo avatar"
yeah we would only interpolate the first chamber for the same reason, after that all SSM secerts are the same across environments.
we thought about moving ci-app1
to the CI Account and changing it to something like /dev/ci-app1
or so, so we can use the fact that chamber can read multiple secrets at once, but ultimately we prefer to have less interpolation of environment names etc
2018-08-28
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
So my customer wants to pay someone to fix that bug around Terraform and beanstalk settings, that we discussed here last week.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
I’m not sure that even if someone can figure out where the bug is and patch it they’ll be able to get it merged in a timely manner.
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
comments/thoughts/suggestions appreciated.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andrew Jeffree are you asking about this one https://sweetops.slack.com/archives/CB6GHNLG0/p1534814857000100
Greetings. I’ve been testing out your beanstalk-environment module and I’ve been having the problem that every-time I run terraform it plans to change everything, even immediately after the initial environment creation etc.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’ll take a look at it
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
If you created a vpc in one tf file… How do you use another tf file to find that vpc and those subnets to deploy resources too
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pericdaniel Terraform works per-folder, meaning everything in the folder will be used. So if you create a VPC in one file, you can use it in all other files in the same folder
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Here is an example
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Collection of Terraform root module invocations for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
Im using separate folders
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform also supports modules in local directories, identified by a relative path starting with either ./ or ../. Such local modules are useful to organize code in more complex repositories, and are described in more detail in Creating Modules. https://www.terraform.io/docs/modules/usage.html#source
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
^ one way of doing it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
another way is to look up the VPC using data sources - you create it in one folder and do terraform apply
, then in another module in another folder you look it up
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
example:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to lookup resources within a Kops cluster for easier integration with Terraform - cloudposse/terraform-aws-kops-metadata
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Anyone ever used: aws_iam_account_alias ? What is the practical use of it ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s a friendly name for the account instead of account ID (which is not easy to remember)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so the URL where you login would be like this:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
hm that’s quite nice actually
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
but also an information give-away in some cases
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yep
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Here is a Terraform trick we used recently. Looks simple, but we really did not know how to do it before It might help somebody.
In some cases, you have a TF module and want to provide some settings in a list
or map
.
And you have a conditional variable (let’s say var.condition1
) which changes the settings for the module.
locals {
settings1 = [
{
name = "1a"
value = "1a"
},
{
name = "1b"
value = "1b"
}
]
settings2 = [
{
name = "2a"
value = "2b"
},
{
name = "1b"
value = "1b"
}
]
}
module "example" {
settings = "${var.condition1 ? local.settings1 : local.settings2}"
}
won’t work because Terraform does not support list
and map
in conditional expressions (maybe V2 will do it better, but we don’t really know).
So here is the slice
pattern (for the lack of a better name)
locals {
settings = [
[
{
name = "1a"
value = "1a"
},
{
name = "1b"
value = "1b"
}
],
[
{
name = "2a"
value = "2b"
},
{
name = "1b"
value = "1b"
}
]
]
from_index = "${var.condition1 ? 0 : 1}"
to_index = "${var.condition1 ? 1 : 2}"
settings_final = "${slice(local.settings, local.from_index, local.to_index)}"
}
module "example" {
settings = "${local.settings_final}"
}
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
I feel like this is one of the many warts that will be addressed in v0.12 https://www.hashicorp.com/blog/terraform-0-12-rich-value-types
As part of the lead up to the release of Terraform 0.12, we are publishing a series of feature preview blog posts. The pos…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Implemented here as an example: https://github.com/cloudposse/terraform-aws-dynamodb/blob/master/main.tf#L11
Terraform module that implements AWS DynamoDB with support for AutoScaling - cloudposse/terraform-aws-dynamodb
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
another way of doing this is to put the conditional eval in the index of the map… map[condition ? true : false]
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
where true and false are the key in your lookup dictionary
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Yep, for maps it will work as well
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
The slice
pattern works better if you need to remove some settings based on condition (and you can’t send empty or default values to the module)
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
love it!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
https://www.reddit.com/r/Terraform/comments/99zri8/gke_regional_cluster_deployment_defining_zones/ you can publish your slice pattern here
0 votes and 1 comment so far on Reddit
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
@Andriy Knysh (Cloud Posse) i cant get this to work^
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what’s the error?
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so, since you are using data sources to lookup the VPC and subnets, two possible issues here:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Did you already provision those VPC and subnets
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
^yes
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
the tags match
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Did you specify the correct filters to look them up?
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
the filter im not sure about
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
this makes sense ot me
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
filter { name = “tag:Name” Values = “${var.AD-Private-Subnet2}”
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
filte for
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
filter for
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
tag name
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
with the value of this variable
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
oh i dont want the tag name tho i want the subnet
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
hmm
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can use tags, but you need to create them with the same tags
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
yes thats what i did
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
the tags match whats in aws
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
and match the other tf file thats creating them
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
the other tf file is in sep folder
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I’ll take a look in 30 mins (in a meeting now)
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
no rush
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
thank you so much!
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
sorry im still learning!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pericdaniel to lookup VPC, you can use id
and filters
https://www.terraform.io/docs/providers/aws/d/vpc.html
Provides details about a specific VPC
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but for subnets
, you use tags
https://www.terraform.io/docs/providers/aws/d/subnet_ids.html
Provides a list of subnet Ids for a VPC
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and vpc_id
is required
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
yea i was tyring to avoid the id due to the fact it changes each time a vpc is created
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
i was looking for a way to have it pass through the current environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can use the id
from the VPC you look up data.vpc.my_vpc.id
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Provides details about a specific VPC
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
All of the argument attributes except filter blocks are also exported as result attributes
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
without inputing the varibale
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
variable
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for subnets
:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
vpc_id = “${data.aws_vpc.my_vpc.id}”
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it will first lookup the VPC and then use its ID (and tags if you want) to lookup the subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(you prob don’t need the tags, you can get all subnets from the VPC by its ID)
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
will i need this variable “AD-Private-Subnet1” {}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(nitpick, consider using all lower case and and underscores - it’s the most common convention for terraform resource names)
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
is there a way to do it without inputing the variable?
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
im missing somthing here
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pericdaniel you can explain what you want to achieve and paste your complete code here (or DM me). (sorry, don’t want it to be http://xyproblem.info :))
Asking about your attempted solution rather than your actual problem
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I love how you always have the term to describe something
Asking about your attempted solution rather than your actual problem
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we made it working with @pericdaniel
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andrew Jeffree so I tested terraform-aws-elastic-beanstalk-environment
and yes, it does re-create all settings
on each plan/apply
setting.1039973377.name: "InstancePort" => "InstancePort"
setting.1039973377.namespace: "aws:elb:listener:22" => "aws:elb:listener:22"
setting.1039973377.resource: "" => ""
setting.1039973377.value: "22" => "22"
setting.1119692372.name: "" => "ListenerEnabled"
setting.1119692372.namespace: "" => "aws:elbv2:listener:443"
setting.1119692372.resource: "" => ""
setting.1119692372.value: "" => "false"
setting.1136119684.name: "RootVolumeSize" => "RootVolumeSize"
setting.1136119684.namespace: "aws:autoscaling:launchconfiguration" => "aws:autoscaling:launchconfiguration"
setting.1136119684.resource: "" => ""
setting.1136119684.value: "8" => "8"
setting.1201312680.name: "ListenerEnabled" => "ListenerEnabled"
setting.1201312680.namespace: "aws:elb:listener:443" => "aws:elb:listener:443"
setting.1201312680.resource: "" => ""
setting.1201312680.value: "false" => "false"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
This feature/bug was present for years and still is not fixed:
https://github.com/hashicorp/terraform/issues/6729 https://github.com/terraform-providers/terraform-provider-aws/pull/901 https://github.com/hashicorp/terraform/issues/6729 https://github.com/hashicorp/terraform/issues/6257 https://github.com/terraform-providers/terraform-provider-aws/issues/280 https://github.com/hashicorp/terraform/issues/11056 https://github.com/terraform-providers/terraform-provider-aws/issues/461
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
nobody is sure who’s bug it is, Terraform or AWS
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(i tested some ideas from the links above, nothing worked)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the only possible solution is to add this:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
lifecycle {
ignore_changes = ["setting"]
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but it’s a hack since it will not update the env if you update any of the settings
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) can you open a new issue here: https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/issues
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
with all your research above?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that way we can track it since this comes up quite frequently
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hate for you to have to explain it everytime
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
@Andriy Knysh (Cloud Posse) yep, am aware it’s an open issue in multiple places. For now we’re ignoring changes to settings in the lifecycle but as you mentioned it’s a hack. The customer wants to pay someone to fix it, but I don’t like their odds.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
sounds like it would be a difficult thing to give an estimate on, so it would probably need to be T&E
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
is anyone using private submodules with codebuild?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
i use codebuild a fair bit… do you mean git submodules? or terraform modules that themselves have modules?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
git submodules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Regarding terraform-aws-elastic-beanstalk-environment
recreating the settings
all the time, here what I think is happening:
- Terraform sends all settings to AWS, but some of them are not relevant to the environment you are deploying
- Elastic Beanstalk accepts all settings, applies the relevant ones, and throws away the rest
- Next time Terraform asks about the settings, Elastic Beanstalk returns a subset of the values and probably in different order
- Terraform can’t decide/calculate if the settings are the same - they sure look different (and would require an
advanced
algorithm to determine if they are the same) - Terraform assigns new ID to the entire array of settings and tries to recreate all of them
- Elastic Beanstalk accepts the settings, applies the relevant ones, and throws away the rest - the cycle repeats
What’s a possible solution?
Introduce var.settings
(list of maps) to be able to provide all the required settings from outside of the module.
It might work, but in practice would be very difficult to know all the needed settings and tedious to implement.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andrew Jeffree ^
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(opened an issue to track any progress on this https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/issues/43)
terraform-aws-elastic-beanstalk-environment recreates all settings on each terraform plan/apply setting.1039973377.name: "InstancePort" => "InstancePort" setting.1039973377.n…
data:image/s3,"s3://crabby-images/93322/93322e8dde6ce485757e9dcaa24a5afb40170539" alt="Andrew Jeffree avatar"
interesting
2018-08-29
2018-08-30
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This fixes the case where a module label is instantiated with a non-default delimiter, and then another label is generated based off the context but uses the default delimiter as the local var take…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jamie any insights?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
checking
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we can override delimiter
for any label. If it’s not provided and context provided, it will be taken from the context. If nothing is provided, the default will be used
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’m reviewing the PR
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Its an easy fix
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
I see that in the PR it has been broken out into less condense parts so that each step can be explained.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@mrwacky yea looks like it will be resolved in 0.12
, thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
As part of the lead up to the release of Terraform 0.12, we are publishing a series of feature preview blog posts. The pos…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no need for the slice
pattern
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
So much goodness in 0.12
, they’re even addressing JSON warts:
https://www.hashicorp.com/blog/terraform-0-12-reliable-json-syntax#comments-in-json
As part of the lead up to the release of Terraform 0.12, we are publishing a series of feature preview blog posts. The pos…
data:image/s3,"s3://crabby-images/729f0/729f03b0209d87a97f0c17b7ad059dea1f196bb7" alt="krogebry avatar"
So does that mean TF will be one step closer to CloudFormation?
data:image/s3,"s3://crabby-images/729f0/729f03b0209d87a97f0c17b7ad059dea1f196bb7" alt="krogebry avatar"
ducks for cover
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hopefully they won’t have too many issues in V2 and we don’t spend too much time on resolving them
data:image/s3,"s3://crabby-images/88ea5/88ea593e096681f6cf9bade89466b33266d99f34" alt="stobiewankenobi avatar"
0.12 will be amazing.
data:image/s3,"s3://crabby-images/88ea5/88ea593e096681f6cf9bade89466b33266d99f34" alt="stobiewankenobi avatar"
Literally doing zero work on new tf stuff until it drops
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
lololol
data:image/s3,"s3://crabby-images/6c28f/6c28f72506a18bd678ad974a747f8c062cf09cc7" alt="rms1000watt avatar"
roll d20
data:image/s3,"s3://crabby-images/88ea5/88ea593e096681f6cf9bade89466b33266d99f34" alt="stobiewankenobi avatar"
lolol
data:image/s3,"s3://crabby-images/88ea5/88ea593e096681f6cf9bade89466b33266d99f34" alt="stobiewankenobi avatar"
got’em
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
@Gabe
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
@Gabe has joined the channel