#terraform (2018-10)
Discussions related to Terraform or Terraform Modules
Archive: https://archive.sweetops.com/terraform/
2018-10-01
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
so with your beanstalk module… How can I add user data?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
.ebextensions
is not enough?
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
I need to get add swap to instances as they are created. someone before me had created ebextensions to add script to add swap, but when instances are refreshed or whatever it doesnt work. also he didn’t add it to fstab so on restart no swap.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we did it that way for swap
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
also turns out ebextensions are only executed once on environment creation (i think), and any changes later are ignored.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it’s been a couple years since i looked at it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but i think there were sections that run on every build
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and some that only ran on creation
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hmm i’ll have to research into it more. couldn’t find any details about that yet
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i found our old code for that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
commands:
00_add_swap_space:
command: "/tmp/add-swap-space.sh"
files:
"/tmp/add-swap-space.sh":
mode: "000755"
content: |
#!/bin/bash
set -o xtrace
set -e
SWAP_SIZE=$(/opt/elasticbeanstalk/bin/get-config environment | jq -r ".SWAP_SIZE")
if [ "$SWAP_SIZE" == "0" ];
then
echo "Swap is not enabled"
exit 0
fi
if grep -E 'SwapTotal:\s+0+\s+kB' /proc/meminfo; then
echo "Enabling swap space (${SWAP_SIZE} mb)"
dd if=/dev/zero of=/var/swapfile bs=1M count=$SWAP_SIZE
/sbin/mkswap /var/swapfile
chmod 000 /var/swapfile
/sbin/swapon /var/swapfile
else
echo "Not creating additional swap space"
fi
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yep thats essentially what i have
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
minus the command part
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
maybe use folder hooks? can’t speak from experience, but this guy suggests it: https://github.com/equivalent/scrapbook2/blob/master/archive/blogs/2016-08-22-aws-elasticbeanstalk-hooks.md#direct-ebextension-command-enxecution
web-development notes and archive of Old articles - equivalent/scrapbook2
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"
In aws elasticbean talk. When we setup extensions in .ebextensions i wonder what is difference between commands and container_commands My command is like this container_commands: 04_insert_a…
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hmm so in my case the command does run, but it does nothing because swapfile already exists. it just doesn’t actually re-enable it
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
if instance is rebooted
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Just call “swapon /the/swapfile”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So if the instance is rebooted, it checks for the file. If it’s found it calls swapon, else it creates it and calls swap on
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
yeah i’ll add that. thank you
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i do like your ENV for swapsize
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
i might steal that idea
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
lol
2018-10-02
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
I just had a second former co-worker independently discover this comment and thank me for it https://github.com/hashicorp/terraform/issues/9368#issuecomment-253950367 </brag>
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha, very nice - like the fix
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
also, props for using template_file
over HEREDOCs - hate those
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
though in the particular issue, I’d argue the correct fix is to use an iam_policy_document
which rather than templated JSON.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Generates an IAM policy document in JSON format
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
Well, in my defense, I made that comment 2 years ago, when I had 2 years less TF experience, and might predate iam_policy_document
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha very likely!
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"
it’s awesome though.. i have been coming across a lot of members contributions/comments
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
Where’s TF 0.12, we’re dying here ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@maarten, @Daren, @jamie just in the past week
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"
end of oct
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
<—– excited but not excited
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have 100+ modules to update
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Ryan Ryke what do you think about this: https://github.com/cloudposse/terraform-aws-ecs-container-definition/pull/12
The usage for the module appears to be in a single container context resource "aws_ecs_task_definition" "this" { container_definitions = "${module.container_definition.js…
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
looks pretty cool, i like the idea.
The usage for the module appears to be in a single container context resource "aws_ecs_task_definition" "this" { container_definitions = "${module.container_definition.js…
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
im not totally sure about which context this is used in, unless you needed a sidecar or some sort of container to link to
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
other wise you could just call the module twice… i am sure im missing a use case here
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea - sidecar use-case i think
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
by @stephen
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
hey all. I’m quite confused by the ecr_repository_name
variable to the terraform-aws-ecs-alb-service-task
module. There are no references to it in the configuration. How does one link an ECR repo to a ECS task?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is in the imagedefinition.json
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"
which is created as part of the build process
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
seems like that’s related to codepipeline being enabled? Is it the case that terraform-aws-ecs-web-app
can’t be configured with an image in ECR unless it’s used with codepipeline?
Happy to open a PR if that’s the case. Just want to be sure I’m understanding the current setup correctly.
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
I’ve managed to fix this for myself locally by prepending the ECR registry name to the image name in container_definition
:
container_image = "${module.ecr.registry_url}:${var.container_image}"`
Unfortunately, since the image repository is defined within aws-ecs-web-app
module, I don’t see a way to apply this fix without modifying aws-ecs-web-app
itself. Currently working with a local clone for this reason…
Does anyone know a way to do this just by passing the right var.container_image
to aws-ecs-web-app
?
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
if it requires a change to container_definition
, it seems like it should be conditioned on codepipeline_enabled
. Sound correct?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if using CI/CD, which is the use-case we optimized for, the repo is set with the buildspec.yaml
which defines how to update the imagedefinitions.json
file
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
did you take a look at the gist I sent you above?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @dan
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
look here for an example https://github.com/cloudposse/terraform-aws-ecs-web-app/blob/master/main.tf#L66
Terraform module that implements a web app on ECS and supports autoscaling, CI/CD, monitoring, ALB integration, and much more. - cloudposse/terraform-aws-ecs-web-app
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
thanks @Andriy Knysh (Cloud Posse)
if you search for ecr_repository_name
in that repo, you’ll see that it’s only references in the example. Do you know where it gets used?
Terraform module that implements a web app on ECS and supports autoscaling, CI/CD, monitoring, ALB integration, and much more. - cloudposse/terraform-aws-ecs-web-app
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module that implements a web app on ECS and supports autoscaling, CI/CD, monitoring, ALB integration, and much more. - cloudposse/terraform-aws-ecs-web-app
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dan i recommend starting with the terraform-aws-ecs-web-app
module for a more “turnkey” app
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
thanks @Erik Osterman (Cloud Posse). I am still curious to find where this variable is used. Neither the web app nor the service task wrappers reference it outside of the docs or examples…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
of course, if you need to do something which doesn’t fit the mold, you can always use the terraform-aws-ecs-alb-service-task
as a building block.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the web app module will be a good reference implementation for you
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
man! we have too man dans for me to keep track of…
2018-10-03
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
did you take a look at the gist for the buildspec.yaml
?
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
yes. can you confirm it’s only relevant if i’m using codepipeline?
I see that I could prepend the equivalent of
$AWS_ACCOUNT_ID.dkr.ecr.us-west-2.amazonaws.com/$IMAGE_REPO_NAME
to the image name, though the repository name seems to be only accessible from within aws-ecs-web-app
.
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
The docs for codepipeline_enabled
say:
“A boolean to enable/disable AWS Codepipeline and ECR”
Which makes me think the current setup doesn’t permit pulling images from ECR without codepipeline_enabled
.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
i hard coded the ecr uri into the ecs-web-app module
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Ryan Ryke ok, so it sounds like we’re missing something?
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
It’s a little chicken and egg
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
It needs to know the repo and tag before It can build the container definition
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
And it can’t get the tag until it runs a container definition from the build spec
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
In the car atm
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
I have a quick question about https://www.terraform.io/docs/providers/aws/r/autoscaling_group.html#waiting-for-elb-capacity
So I typically use min_elb_capacity
and deploy a new LC+ASG together when config/code changes within my ASG instances.
A colleague hit me up today with this observation –
“””
Assuming a the old ASG has scaled-out (increased instance-count) due to scaling-rules
– and because the terraform value for min_elb_capacity
is not dynamic
this will cause an unwanted reduction in the instance count when the new ASG is deployed.
“””
Has anyone seen a method of propagating the current desired_capacity
from the currently active ASG to the newly proposed ASG during the terraform plan
phase?
Provides an AutoScaling Group resource.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think the best thing would be to ignore_changes
to desired_capacity
data:image/s3,"s3://crabby-images/3877f/3877fc1c6aed2b7d05b8928560115dabaa0ea513" alt="tamsky avatar"
OK, I’ll try that.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
has anyone touched this module in a while https://github.com/cloudposse/terraform-aws-cloudwatch-flow-logs
Terraform module for enabling flow logs for vpc and subnets. - cloudposse/terraform-aws-cloudwatch-flow-logs
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
looks like kinesis is in there not 100% sure what its needed for
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Ryan Ryke looks like the module was created almost a year ago and never updated. We can take a look at it together if you want to use it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@tamsky regarding desired_capacity
:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
You may want to omit desired_capacity attribute from attached aws_autoscaling_group when using autoscaling policies. It’s good practice to pick either manual or dynamic (policy-based) scaling
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Provides an AutoScaling Scaling Group resource.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s what we use here https://github.com/cloudposse/terraform-aws-ec2-autoscale-group/blob/master/autoscaling.tf
Terraform module to provision Auto Scaling Group and Launch Template on AWS - cloudposse/terraform-aws-ec2-autoscale-group
2018-10-04
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dan we took a look into your specific question with specifying the ECR repo with terraform-aws-ecs-alb-service-task
module
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
What you want to do is use the terraform-aws-ecs-container-definition
module to create a JSON task definition.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
set the container_image
to the canonical “docker” url to the image
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform module to generate well-formed JSON documents (container definitions) that are passed to the aws_ecs_task_definition Terraform resource - cloudposse/terraform-aws-ecs-container-definition
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"
then once you have all that, pass the container definition JSON as the value of container_definition_json
of the terraform-aws-ecs-alb-service-task
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform module which implements an ECS service which exposes a web service via ALB. - cloudposse/terraform-aws-ecs-alb-service-task
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) is going to remove that confusing ecr_repository_name
which is not used
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dan example added here https://github.com/cloudposse/terraform-aws-ecs-alb-service-task/pull/15/files#r222824398
what Remove unused vars Update README with examples and descriptions Add usage example why The vars were declared but never used and they are unnecessary Add example for specifying container def…
2018-10-05
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
new version released with usage examples and explanation how to setup the container image https://github.com/cloudposse/terraform-aws-ecs-alb-service-task
Terraform module which implements an ECS service which exposes a web service via ALB. - cloudposse/terraform-aws-ecs-alb-service-task
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Gabe thanks for the PR https://github.com/cloudposse/terraform-aws-dynamic-subnets/pull/34
what Support use of tags by label modules why Interoperability with all modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
going to have @Andriy Knysh (Cloud Posse) review - then we’re good to merge
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
thank you
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
awesome thank you!
2018-10-07
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for those interested and want to follow along, we’re working on some enhancements for atlantis
2018-10-10
data:image/s3,"s3://crabby-images/0d10e/0d10e1e0a69f6cba23942f3016cd5bcbfe8e9514" alt="Matthew avatar"
@Andriy Knysh (Cloud Posse) I’ve been out of the loop on your EKS plugin, but is it production ready?
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"
all modules were tested on AWS
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/0d10e/0d10e1e0a69f6cba23942f3016cd5bcbfe8e9514" alt="Matthew avatar"
Thank you I am going to use it today
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an AWS AutoScaling Group, IAM Role, and Security Group for EKS Workers - cloudposse/terraform-aws-eks-workers
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and here is a complete working example (the one we tested)
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/0d10e/0d10e1e0a69f6cba23942f3016cd5bcbfe8e9514" alt="Matthew avatar"
Thank you good sir
2018-10-11
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
@bober2000 https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
Under resource "aws_elastic_beanstalk_environment" "default" {
you’ll see similar settings
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
@Andy so just insert my settings to resource “aws_elastic_beanstalk_environment” “default” {
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
ok, thanks
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
will try this
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
yup or set a variable for value = "8.6.4"
part so you can easily switch between versions for other apps
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
sorta depends on your use cases and if you’ll have multiple apps or environments
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
just used this module from git directly source = “git://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment.git?ref=master>”
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
so I need to clone repo to localhost and change it there
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
got it
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
yup
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @bober2000, welcome
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Andy thanks for answering the questions
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@bober2000 if you want to open a PR to add the settings to the module, we’ll review it
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
@Andriy Knysh (Cloud Posse) sure! Will do this as fast as understood how
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
here are the steps that should help you:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
-
Fork the repo into your GitHub account
-
Create a new branch
-
Modify the code in your branch
Add this
setting {
namespace = "aws:elasticbeanstalk:container:nodejs"
name = "NodeVersion"
value = "8.6.4"
}
-
Test on AWS (terraform plan/apply)
-
Open a Pull Request against our repo
-
We review and merge your changes into our repo
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
8.6.4
should be a new variable, e.g. nodejs_version
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
setting {
namespace = "aws:elasticbeanstalk:container:nodejs"
name = "NodeVersion"
value = "${var.nodejs_version}"
}
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Oh, thanks - I know how to contribute using GitHub - I mean I’m still only newbie in terraform syntax
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Will add this - thanks for a guide
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
Don’t forget to add to variables.tf as well
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"
and then rebuild README by executing the following commands in the module folder:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make init
make readme/deps
make readme
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Anyone know if there is a terraform module(+lambda) out there for AWS service limit monitoring ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
That would be a great one!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Haven’t seen though…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I want a module for billing alerts too
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
https://s3.amazonaws.com/solutions-reference/limit-monitor/latest/limit-monitor.pdf there is a CF template https://s3.amazonaws.com/solutions-reference/limit-monitor/latest/limit-monitor.template Easiest to just TF around it
data:image/s3,"s3://crabby-images/f9284/f9284a413dd37970df022308f1ed26d8dea2147e" alt="GFox)(AWSDevSecOps avatar"
My requirement is to not to delete and not even trying to delete, since S3 is the backend. Currently it’s trying to delete and failing since versioning is enabled. Was trying to set a deletion policy to “retain” (S3) running terraform. (moot) Was wondering if there is option to tell terraform not to delete backend S3 ??
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@GFox)(AWSDevSecOps can you add some additional context? sounds like you might be talking about the terraform-aws-tfstate-backend
module?
data:image/s3,"s3://crabby-images/f9284/f9284a413dd37970df022308f1ed26d8dea2147e" alt="GFox)(AWSDevSecOps avatar"
Thank you @Erik Osterman (Cloud Posse), working on it, I’m not an aws guy yet, more azure and openstack, but helping a friend right now, while l’m reading up looking into it, and, when I get a better picture, will def ping you back
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Aha then yes there are a few options
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Sorry, I see now more clear what you are asking
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So when you create the bucket resource you will want to add a lifecycle block that says prevent destroy
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@GFox)(AWSDevSecOps you need to put tfstate-backend
into a separate folder, provision it using TF local state, then import the state into the tfstate-backend
bucket
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
all other modules are in different folders, so when you run terraform destroy
on them, TF will not attemp to destroy the state bucket
data:image/s3,"s3://crabby-images/f9284/f9284a413dd37970df022308f1ed26d8dea2147e" alt="GFox)(AWSDevSecOps avatar"
wow, quick responses, great help and great stuff
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also take a look at our docs where we describe the process https://docs.cloudposse.com/reference-architectures/cold-start/#provision-tfstate-backend-project-for-root
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
@Andriy Knysh (Cloud Posse) PR for adding NodeJS version select https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/pull/50
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Thanks @bober2000!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Left 1 comment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@bober2000 LGTM thanks. Just rebuild README
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
@Erik Osterman (Cloud Posse) @Andriy Knysh (Cloud Posse) README ready, linting too
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
thanks! waiting on @Andriy Knysh (Cloud Posse) for final approval
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@bober2000 merged to master. Thanks for the PR!
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
Thanks for the help here on the terraform-aws-ecs-web-app ECR issue a few days ago!
I’m now wondering if I’ve misunderstood the use-case for the module. Is it ok to have the instances it defines live on a public subnet? The only way to specify the subnets is via ecs_private_subnet_ids
, which leads me to believe it should only be used on private subnets. In my use-case, the containers need internet access. When I look under the hood, I don’t see any reason for the “private” qualifier. Is it just a poorly-named variable?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it was designed with the expectation that the tasks are on a private subnet
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
which means your VPC needs a NAT gateway to reach the internet
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have you seen our VPC and subnet modules? Those will take care of it
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
Ah, thanks. Will look now.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(though I suppose it will just work if you give it public subnet IDs)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
even though it’s called private_...
(just a hunch)
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
that’s what I was hoping for. Will report back.
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"
if not, and you want to submit a PR, will review it promptly
2018-10-12
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Hi again. When trying to
terraform destroy
I’m getting several errors: module.elastic_beanstalk_environment.aws_s3_bucket.elb_logs (destroy): 1 error(s) occurred: aws_s3_bucket.elb_logs: error deleting S3 Bucket (develop-dev-vitaliimorvaniukdev-logs): BucketNotEmpty: The bucket you tried to delete is not empty status code: 409 module.dev_front_end.module.logs.aws_s3_bucket.default (destroy): 1 error(s) occurred: aws_s3_bucket.default: error deleting S3 Bucket (develop-dev-front-dev-vitalii.morvaniuk-dev-logs): BucketNotEmpty: The bucket you tried to delete is not empty. You must delete all versions in the bucket. status code: 409
force_destroy = true
is setted
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
what should I check ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
was force_destroy = true
set from the very beginning?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh, this is a tricky thing i discovered a few months ago.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if you change force_destroy = true
but do not terraform apply
, it doesn’t register
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@bober2000 and if the rest has been deleted already, best is to do a terraform apply_target on module.elastic_beanstalk_environment.aws_s3_bucket.elb_logs with the force_destroy = true option. And then the destroy again.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Yes force_destroy = true was set from the beginning
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
[empty bucket]-button
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Its what I’m doing now - but I’d like it to be deleted automatically
[empty bucket]-button
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i’m not quite sure what to look into
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in older versions of terraform, it was common that versions weren’t force deleted
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
terraform –version Terraform v0.11.7
- provider.aws v1.40.0
- provider.null v1.0.0
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
This issue was originally opened by @osterman as hashicorp/terraform#7854. It was migrated here as part of the provider split. The original body of the issue is below. Terraform Version Terraform v…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but that’s been working for me as of relatively recently - using our terraform-aws-tfstate-backend
module which has versions
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Erik, you have a long history of tf issues
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hah, that’s ironic
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
since v0.6.16
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
its more tragic hehe, it’s super old
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Ok, one more question - I need to add RDS instance to my beanstalk environment - as far as I see there are no option for this - should I do it separatly and after that add something like this:
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_USERNAME"
value = "${aws_db_instance.rds-app-prod.username}"
}
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_PASSWORD"
value = "${aws_db_instance.rds-app-prod.password}"
}
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_DATABASE"
value = "mydb"
value = "${aws_db_instance.rds-app-prod.name}"
}
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_HOSTNAME"
value = "${aws_db_instance.rds-app-prod.endpoint}"
}
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
For prod it’s recommended to do it separately http://www.michaelgallego.fr/blog/2013/10/26/do-not-associate-rds-instance-with-beanstalk-environment/
Discuss about some pros and cons of associating a RDS instance with an Elastic Beanstalk environment
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
And then just pass RDS Hostname username/password etc as variables to the environment
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Ok, thanks
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
https://github.com/cloudposse/terraform-aws-rds so something like that and then you can use the outputs
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
2018-10-15
data:image/s3,"s3://crabby-images/73ab5/73ab529026692988b19c1e926c719bb6eed09bd7" alt="Miguel Mendez avatar"
First let me say thanks for contributing great terraform modules. I have a question though. I need a simple redis elastic cache cluster. I have looked at https://github.com/cloudposse/terraform-aws-elasticache-redis but this seems to be geared towards clusters with replication such as https://docs.aws.amazon.com/AmazonElastiCache/latest/red-ug/Replication.Redis.Groups.html#Replication.Redis.Groups.Cluster. Is this correct or my assumptions are wrong? Thanks in advance for any feedback.
Terraform module to provision an ElastiCache Redis Cluster - cloudposse/terraform-aws-elasticache-redis
Each shard in a replication group has a single read/write primary node and up to 5 read-only replica nodes.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @Miguel Mendez
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes the module does not support https://www.terraform.io/docs/providers/aws/r/elasticache_cluster.html
Provides an ElastiCache Cluster resource.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Provides an ElastiCache Replication Group resource.
data:image/s3,"s3://crabby-images/73ab5/73ab529026692988b19c1e926c719bb6eed09bd7" alt="Miguel Mendez avatar"
OK, any plans supporting it?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Most of our modules are driven either by client engagements or community contributions. As of right now, we don’t have any clients asking for it :-)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We are really good about promptly reviewing PRs and nearly accept all contributions. If you’re interested, please take a stab at it!
data:image/s3,"s3://crabby-images/73ab5/73ab529026692988b19c1e926c719bb6eed09bd7" alt="Miguel Mendez avatar"
OK great. I will create then a module and submit a PR. Thanks once again for your contributions.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Awesome @Miguel Mendez ! Thanks for taking a look at it
data:image/s3,"s3://crabby-images/19911/19911457ab776929c2379d7a6ced83811e7ce365" alt="nicgrayson avatar"
Hey all, I’m trying to get https://github.com/cloudposse/terraform-aws-eks-cluster to work. No nodes are showing up when i do kubectl get nodes. The userdata log on the instance looks fine.
Terraform module for provisioning an EKS cluster. Contribute to cloudposse/terraform-aws-eks-cluster development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@nicgrayson did @Andriy Knysh (Cloud Posse) share the reference implementation?
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/19911/19911457ab776929c2379d7a6ced83811e7ce365" alt="nicgrayson avatar"
I’m using tf from the readme
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
^ what we deployed and tested
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to apply the ConfigMap for the worker nodes to join the cluster
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can apply it manually, or using https://github.com/cloudposse/terraform-root-modules/blob/master/aws/eks/kubectl.tf
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"
(EKS does not do it automatically)
data:image/s3,"s3://crabby-images/19911/19911457ab776929c2379d7a6ced83811e7ce365" alt="nicgrayson avatar"
ah okay thanks
data:image/s3,"s3://crabby-images/19911/19911457ab776929c2379d7a6ced83811e7ce365" alt="nicgrayson avatar"
Worked like a charm
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
nice
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
let us know if any issues
2018-10-16
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Hi all. I’m trying to create RDS instance using https://github.com/cloudposse/terraform-aws-rds
module "elastic_beanstalk_rds" {
source = "git::<https://github.com/cloudposse/terraform-aws-rds.git?ref=master>"
namespace = "${var.namespace}"
stage = "${var.environment}"
name = "${var.user_account_name}"
dns_zone_id = "${var.parent_zone_id}"
host_name = "db"
security_group_ids = ["${module.vpc.vpc_default_security_group_id}"]
database_name = "app"
database_user = "admin"
database_password = "password"
database_port = 5432
multi_az = "false"
storage_type = "gp2"
allocated_storage = "5"
engine = "postgresql"
engine_version = "9.6.6"
instance_class = "db.t2.micro"
db_parameter_group = "default.postgres9.6"
#parameter_group_name = "default.postgres9.6"
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
But getting
module.elastic_beanstalk_rds.aws_db_instance.default: Resource 'aws_db_parameter_group.default' does not have attribute 'name' for variable 'aws_db_parameter_group.default.*.name'
error
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
what I’m doing wrong ?
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
try passing a list instead
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
see if that works, unfamiliar with the module but might point you in the right direction if so
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
er hm, likely from the commented out parameter_group_name
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
looks like it’s checking for the length of that here: https://github.com/cloudposse/terraform-aws-rds/blob/master/main.tf#L54
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @bober2000 and @jarv
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if parameter_group_name
is not provided, the default is ""
(empty string)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it looks like a race condition
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
oh, hm didn’t see that.. ~so guess just a depends_on should prevent that as well~an ignore this suggestion probably, think I need more sleep
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
looks like it’s the ‘famous’ issue with TF counts
after the latest release (count expressions have been changed)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@bober2000 can you try the previous release source = "git::<https://github.com/cloudposse/terraform-aws-rds.git?ref=tag/0.4.0>"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that one was working for a long time
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and we’ll look into the issue with the latest release 0.4.1
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also, don’t use master
in your code (git::<https://github.com/cloudposse/terraform-aws-rds.git?ref=master
>), always pin to a release (for all modules). Modules get changed and there is a possibility of regression
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
thanks for tips - will try
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
does anyone have an example for using the event selector in the cloudtrail module? https://registry.terraform.io/modules/cloudposse/cloudtrail/aws/0.5.0?tab=inputs trying to capture all S3 events https://www.terraform.io/docs/providers/aws/r/cloudtrail.html#event_selector
Provides a CloudTrail resource.
data:image/s3,"s3://crabby-images/16cf1/16cf12bfaf7fe0b5c40dac4207a7ca03cd951fc7" alt="markmutti avatar"
@shaiss That doc references the Terraform “cloudtrail” resource here:
event_selector
Description: Specifies an event selector for enabling data event logging, It needs to be a list of map values. See: <https://www.terraform.io/docs/providers/aws/r/cloudtrail.html> for details on this map variable
Default: []
I happen to be using that Terraform resource and am using the one from this example: https://www.terraform.io/docs/providers/aws/r/cloudtrail.html#logging-all-s3-bucket-object-events
Provides a CloudTrail resource.
data:image/s3,"s3://crabby-images/16cf1/16cf12bfaf7fe0b5c40dac4207a7ca03cd951fc7" alt="markmutti avatar"
@shaiss (It’s possible you already know this and that I’ve been no help at all. Hopefully not the case)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @markmutti
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@shaiss let us know if it’s working for you
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
@markmutti I’ll chk your link. thx @Andriy Knysh (Cloud Posse) I stepped away for lunch. Belly full, I’m now ready to get back to coding
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
@markmutti so I get the example of using the map that’s listed in your link IF I was using the default/built in resource “aws_cloudtrail”. However, I’m trying to use the cloudposse cloudtrail module which wants a list for event_selector, not a map. This is where I’m banging my head
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
ie. event_selector = {[data_resource = “AWS::Object”]}
my syntax is probably wrong
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@shaiss try this
event_selector = [{
read_write_type = "All"
include_management_events = true
data_resource {
type = "AWS::S3::Object"
values = ["arn:aws:s3:::"]
}
}]
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i guess it was changed to be a list in the last commit so many event selectors could be specified
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
@Andriy Knysh (Cloud Posse) nope: **
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
Error: module.cloudtrail.aws_cloudtrail.default: event_selector.0.data_resource: should be a list
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what Change the event_selector var from a map to a list type. why It is currently a type map, that then gets put inside a list. Even though it is a null map by default, because it is embedded int…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if not working, try the previous release (which was tested)
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
ok, let me try that now
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
0.4.2 of the cloudtrail module still gives the same “should be a list” error
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
same w/ 0.4.1
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
module "cloudtrail" {
source = "cloudposse/cloudtrail/aws"
version = "0.4.2"
name = "${var.cloudtrailbucket["name"]}"
stage = "${var.cloudtrailbucket["stage"]}"
namespace = "${var.cloudtrailbucket["namespace"]}"
s3_bucket_name = "${module.cloudtrail-s3-bucket.bucket_id}"
event_selector = [{
read_write_type = "All"
include_management_events = true
data_resource {
type = "AWS::S3::Object"
values = ["arn:aws:s3:::"]
}
}]
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the code above generates “should be a list” error?
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
yep
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i’ll try to reproduce and fix the issue when I get some spare time
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
has anyone here used the terraform-aws-alb
and terraform-aws-alb-ingress
modules to configure a load balancer to redirect http to https? It’s an obvious option when adding an ingress rule via the AWS UI, but I’m lost finding the equivalent option in the cloudposse modules. I feel like I’m missing something simple…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dan we don’t have this implemented right now. @Ryan Ryke wanted the same thing. Not sure what he ended up doing.
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
@Erik Osterman (Cloud Posse) good to know - thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Looks like support for this was released in August (after our first look at it)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Community Note Please vote on this issue by adding a reaction to the original issue to help the community and maintainers prioritize this request Please do not leave "+1" or "me to…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Support for fixed-response and redirect actions has been merged into master via #5430 and will release with version 1.33.0 of the AWS provider, later this week. (August 20)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dan if you get a chance to implemented, we would love a PR
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
resource "aws_lb_listener" "front_end" {
load_balancer_arn = "${aws_lb.front_end.arn}"
port = "80"
protocol = "HTTP"
default_action {
type = "redirect"
redirect {
port = "443"
protocol = "HTTPS"
status_code = "HTTP_301"
}
}
}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Provides a Load Balancer Listener resource.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@dan
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@LeoGmad I think you guys might dig this too….
data:image/s3,"s3://crabby-images/90f80/90f80fb0f49c149be7ca95fd80da815032419b6e" alt="LeoGmad avatar"
@LeoGmad has joined the channel
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
yeah, i would be interested in that. i can try and put a pr in this weekend. for now they are handling it inside the container
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
not totally sure how you would implement it though
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Ryan Ryke I think we would add this to the terraform-aws-alb
module
resource "aws_lb_listener" "https_redirect" {
count = "${var.https_redirect_enabled == "true" ? 1 : 0}"
.... # code from above
}
Somewhere here. https://github.com/cloudposse/terraform-aws-alb/blob/master/main.tf#L27
And then a ternary here to select the appropriate ARNs: https://github.com/cloudposse/terraform-aws-alb/blob/master/outputs.tf#L38
Terraform module to provision a standard ALB for HTTP/HTTP traffic - cloudposse/terraform-aws-alb
Terraform module to provision a standard ALB for HTTP/HTTP traffic - cloudposse/terraform-aws-alb
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
ahh right something like that might make sense
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(or maybe return 0 ARNs for HTTP if redirect enabled)
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
when is .12 coming out?
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
maybe hashiconf?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, that’s my expectation
2018-10-17
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
hey
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
quick one
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
let’s say I want to only deploy your beautiful jenkins terraform solution
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
what is a good practice to start?
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
copy the main.tf from the examples folder to the root of the project and run terraform init .. plan .. apply?
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
I wasnt able to find that skimming the readme
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
thx
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
Terraform module to build Docker image with Jenkins, save it to an ECR repo, and deploy to Elastic Beanstalk running Docker stack - cloudposse/terraform-aws-jenkins
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
for now I created a deploy folder and run terraform init deploy/ etc.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @ff
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
hey
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so I think you already have your project structure similar to this https://github.com/cloudposse/terraform-root-modules/tree/master/aws
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"
each app/module should be in a separate folder
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
got it
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
ah I see
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you add for example jenkins
folder
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and copy our example in there
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then cd to the folder and run terraform plan/apply
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
thanks that was the hint I was missing
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
back to work
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
1 sec
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and pin all modules to a release
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
don’t use master
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
master
can be changed/updated and there is a possibility to introduce regression
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
got it
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
this is awesome stuff … how did we infrastructure back in the 2000s
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
or even further back
data:image/s3,"s3://crabby-images/16cf1/16cf12bfaf7fe0b5c40dac4207a7ca03cd951fc7" alt="markmutti avatar"
@ff That is terrifying to think about. We did it very badly.
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
lots of metal and cables
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
and sometimes even documentation
data:image/s3,"s3://crabby-images/16cf1/16cf12bfaf7fe0b5c40dac4207a7ca03cd951fc7" alt="markmutti avatar"
Oh man, and SSHing into a million machines to apply patches, config drift, you name it
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
or DRBD
2018-10-18
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
hey again… making some progress with the jenkins-terraform
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
but
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
ending up here
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
I already learned about the other issue with the empty value for the github auth token and added a - in the value as described in https://github.com/cloudposse/terraform-aws-jenkins/issues/11
Hi, I've just cloned the repo to test it and I'm following the doc, however, it is asking for more variables than it is described. My steps were: git clone terraform init terraform plan It …
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
but here is a dead end. I don’t see a name tag either. Please advise
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
I now worked - it was obvious after asking the question here - using another tag name and value (before: Terraform = “true”, after Department = “abc”)
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
whatever
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
It only works once. Once the tag has been set, the next run fails.
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
this is my config - please help, I am at a dead end
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @ff what’s exactly are you seeing? terraform apply
first time works, but second time fails?
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
yes
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
if I change the tags, it works once again
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
by the way, just filed a pull request - it only worked with a personal access token instead of “-”
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
It just worked with a personal access token for me.
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
Aaand the next PR https://github.com/cloudposse/jenkins/pull/14
Updated to latest Jenkins version since there were a lot of notifications regarding security issues etc.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
anyone have a good read replica module
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
rds read replica
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Ryan Ryke hrmmm I believe we recently made some fixes to support this use-case
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Trying to remember who here was working in that
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) do you remember who?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Gladly?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Daren gave us the example code that they used, but it was to help someone else
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Let me check
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
resource "aws_db_subnet_group" "replica" {
name = "replica"
subnet_ids = ["xxxxxxx", "xxxxxxx", "xxxxxx"]
}
resource "aws_kms_key" "repica" {
deletion_window_in_days = 10
enable_key_rotation = true
}
resource "aws_db_instance" "replica" {
identifier = "replica"
replicate_source_db = "${var.source_db_identifier}"
instance_class = "${var.instance_class}"
db_subnet_group_name = "${aws_db_subnet_group.replica.name}"
storage_type = "io1"
iops = 1000
monitoring_interval = "0"
port = 5432
kms_key_id = "${aws_kms_key.repica.arn}"
storage_encrypted = true
publicly_accessible = false
auto_minor_version_upgrade = true
allow_major_version_upgrade = true
skip_final_snapshot = true
}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Here’s the link to the discussion
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Maybe some more juice there
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
right, so no module just a raw resource
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Erik Osterman (Cloud Posse) we helped Gladly with this module terraform-aws-rds-replica-vpc
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
they have it, but it’s not public
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea, so IMO not sure it makes sense to have a module for it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This customer created a private module that does this by creating a vpc, subnet and RDS instance configured as a replica
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
But then that means that vpc should be used basically for nothing else
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, that was mostly for cross-region replica
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so more complex than prob needed
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This is good for checking the box on a pci compliance box
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Ryan Ryke can you provide the use-case you are solving?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Ryan Ryke if you use Aurora, you don’t need all of that
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
they just want a read replica in prod
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
also true
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
i dont need a module for it
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
there really isnt a whole lot of tf theere
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
i modified @Andriy Knysh (Cloud Posse)’s sample and im done
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
10 minutes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
replica for plain RDS is mostly useful if you need cross-region replication
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
agreed, they want to hit a separate endpoint for reporting
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok, then you need it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
why not Aurora? (historical reasons?)
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
just comfort level for them
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea, but Aurora is faster
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Terraform and encrypted cross-region read replicas used to be a pain IIRC - not sure if still the case
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, this is much easier now. no jumping through hoops.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
probably not anymore https://sweetops.slack.com/archives/CB6GHNLG0/p1536204881000100
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Looks like resolved - https://github.com/terraform-providers/terraform-provider-aws/issues/518
This issue was originally opened by @gdowmont as hashicorp/terraform#11784. It was migrated here as part of the provider split. The original body of the issue is below. Hi, It would be great if ter…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
is there a cloudposse e2e terraform module that just gets me an ecs cluster I can run some one-off (and scheduled, but not persistent) tasks on? looks like the most plausible public one is https://github.com/arminc/terraform-ecs
AWS ECS terraform module. Contribute to arminc/terraform-ecs development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
(or, ya know, start writing your own terraform :))
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes/no
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’ve taken a more decomposed approach to ECS fargate
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
do you require CI/CD?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform module that implements a web app on ECS and supports autoscaling, CI/CD, monitoring, ALB integration, and much more. - cloudposse/terraform-aws-ecs-web-app
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this module does most of the heavy lifting
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you give it a vpc and subnets, and it deploys a traditional “webapp”
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it takes care of setting up the service task, task definition, codebuild, codepipeline, alb rules, autoscaling,etc
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
however, if you have something very simple - where you basically just want “heroku” but on AWS - there’s something else to consider
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
Yeah; I saw that one – it seems to do almost everything besides the cluster, and it’s the cluster I’m really after
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the cluster is a 1-liner
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
OTOH what eventually want is a cron job running a container with some persistent storage, so maybe I should just run k8s instead
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
the cluster resource itself is a oneliner but the instances in it aren’t, right?
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
you still need an autoscaling group and a launch configuration etc
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh, we only deal with Fargate
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
heh that’ll do it – what do you do for persistence in fargate? iirc it doesn’t support docker volumes
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
just bind mounts
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
and IIRC you can’t make the bind mount just point at an EBS volume you control
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, that’s still a drawback. we’re mostly a kubernetes shop.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in an “ideal world” you don’t need the durability in your containers and can offload that to an external backing service ala S3 with object storage
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but i realize that’s not right for everything
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have you seen this? https://github.com/jpignata/fargate
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
i mean, I can mostly use goofys I think, but it sounds easier to just use k8s + ebs storage in the pod
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I’m using this for simple off off stuff.
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
none of the apps that I’m currently using reallllly want a POSIX fs
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
it’s more of a key value store that maybe uses fopen
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, goofys
is a hack
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
plus it requires elevated capabilities for fuse
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
not sure if it will work on ECS Fargate
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
as a security person I don’t want fuse anywhere near my containers tbh
data:image/s3,"s3://crabby-images/88a0e/88a0ee45d0b7f3f3c1343068f2a19fddb9cfe643" alt="lvh avatar"
OK: you convinced me, time to deploy some k8s
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’ve only used goofys
as a last resort
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have EKS modules too
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jsanchez
data:image/s3,"s3://crabby-images/dc9f3/dc9f3c850507092e409eacdbe2882b86968d8061" alt="jsanchez avatar"
@jsanchez has joined the channel
2018-10-20
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Hey guys, thanks for all the work you’ve put into the modules on github, it’s an awesome collection. I’m trying to build out a pipeline to deploy an ecs cluster, and the target group that is created seems to have no targets - I’m having trouble digging through and finding a reason that might cause it. Has anyone run into similar before? I’m using terraform-aws-alb, terraform-aws-ecs-web-app, and terraform-aws-ecs-alb-service-task
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
^ (semi) solved it myself - tasks were never working in the ecs cluster (unable to access my ECR to pull the image, unsure why), so there never were any targets to register. Womp.
2018-10-21
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@George thanks so much!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Sounds like you figured it out
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
also, did you see our example buildspec.yaml
?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
I did, wasn’t quite sure how I would integrate it into what I was using
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
(Or if it replaced some or all of the components, aside from the vpc and subnets)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Hrm… I thought we had a full example somewhere
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
looking
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
here’s a more complete example that helped @Ryan Ryke get up. We really need to add this to our terraform-root-modules
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
I’ll check it when I get back to my machine, thanks for the heads up!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cool - just ping me if you’re stuck
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Outputs define values that will be highlighted to the user when Terraform applies, and can be queried easily using the output command. Output usage is covered in more detail in the getting started guide. This page covers configuration syntax for outputs.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
TIL:
output "sensitive" {
sensitive = true
value = VALUE
}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Note that this is mostly useful in the CI scenario as anyone with access to the state can always terraform output or read it directly.
data:image/s3,"s3://crabby-images/80373/8037326232faccc0c2ecbf3328a31f4ffed41906" alt="Ryan Ryke avatar"
yeah i can help if needed
2018-10-22
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
Found some weird behaviour and managed to file a new issue even with the current Github outage. https://github.com/cloudposse/terraform-aws-rds-cluster/issues/37
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
thanks for looking into it
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@ff try without the availability_zones
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
It does not accept - it’s a mandatory variable
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
been there
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and with availability_zones = []
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hi, availability_zones is EC2 classic, I believe that the module and the examples will get better if EC2 classic support is dropped. The current examples are mixing EC2 Classic params with VPC para…
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
stupid me
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
tryin’
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
nope
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
availability_zones.#: “3” => “0” (forces new resource) availability_zones.1126047633: “eu-central-1a” => “” (forces new resource) availability_zones.2903539389: “eu-central-1c” => “” (forces new resource) availability_zones.3658960427: “eu-central-1b” => “” (forces new resource)
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
and in turn the cluster nodes are also forced new resoruces
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
just remove everything, and create again without az’s
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
then it should work and keep working
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
Got ya. Testing.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
first w/o terraform destory
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
let’s see
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
thanks for the hint
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
sure np, wanted to do a quick pr, but GH is still suffering it seems
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
good old single points of failure
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
will report back in about 15mins when the “apply” has finished
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
haha
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
does not work
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
availability_zones.#: “3” => “0” (forces new resource) availability_zones.1126047633: “eu-central-1a” => “” (forces new resource) availability_zones.2903539389: “eu-central-1c” => “” (forces new resource) availability_zones.3658960427: “eu-central-1b” => “” (forces new resource)
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
availability_zones = []
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
shall I use a terraform destroy and rebuild the environment?
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
but should not make a difference I think
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
so we should be able to actually drop the variable
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
because I assume that an empty bracket means something else than a non existing variable
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ah sorry man, i think you’re right
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Andriy Knysh (Cloud Posse) do you have thoughts on this
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Let me check
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
for the time being I worked around it by using native terraform aws resources
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
nevertheless I thought it might be helpful to fix this for the community
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea, I think we should just drop that variable from the module altogether
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@ff if we do that, does it fix your problems?
data:image/s3,"s3://crabby-images/8bc9e/8bc9ee49a887d84419a5b5a8a46117001fc1043b" alt="ff avatar"
I think so
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
We currently use 0.6 in prod (from before my time) and I’ve been tasked with upgrading to current. State files stored in s3. Anyone got any general guides or info sources on how to go about upgrading? I see projects like terraforming etc, and/or regeneration of state files.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terraform 0.6.x
-> 0.11.x
?
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
(I’ve been tasked with can be read as “hey I wanna do some terraform” “ok here” “no wait wha-“
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
@Erik Osterman (Cloud Posse) yes
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
*0.7 actually, my bad
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hrm… haven’t had to do that big of a jump
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
most important thing is to backup the state files so you have recourse
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
typically, terraform cli is great about upgrading (never downgrading) tf state
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
there maybe some syntax change, but you’ll be warned by terraform of those
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
objective should be to run a terraform plan
and see no changes; however, sometimes terraform changes default values for things in which case you will see changes.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i think in the CHANGELOG
for every release they publish an upgrade path (if necessary)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i would put together some notes after combing though those release notes that can be you run book
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Hmm, so back up the state files, upgrade terraform binary, and terraform plan until it shows no errors?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, that’s all I can think of off the top of my head
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@maarten @jamie any tips?
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
yo
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@George is upgrading some legacy infra from 0.7.x
-> 0.11.x
; any words of wisdom?
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Wait for 12?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
HA
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Lol
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
It comes with an upgrade script
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
good point
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Oh, seriously?
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
ya
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Lemme go investigate
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
the jump to 11 breaks a lot of “sloppy” code practices of older versions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform is a tool for building, changing, and combining infrastructure safely and efficiently. - hashicorp/terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
pre-release available!
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
11 stopped allowing things like output references that are lists when the lists are empty
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
and we spend half of our time working around that with ugly interpolations
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
11 also broke ‘count’, so that calculated count values arent allowed in modules
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
These things will likely still break in 12, but the fixes are much more elegant
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
in terraform 10 you can do
output "the_alb_name" {
value = "${aws_ecs_service.app_with_lb_awsvpc.*.name}"
}
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
and if aws_ecs_service.app_with_lb_awsvpc
wasn;t created… it calmly shows an empty value
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
without crying about it
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
in 11, if you want your output to work with an empty list from a resource, then its all:
output "the_alb_name" {
value = "${join("",compact(concat(list(""),aws_ecs_service.app_with_lb_awsvpc.*.name)))}"
}
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
to get the same output without an error
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Hmm, I’ll have to review the erm…state of the current configs we have. Unsure if my predecessor wrote anything that takes advantage of those features. Thanks for the explanation and heads up about 0.12!
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Your predesessor will have taken advantage of them
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
since pre 11, that was just how it was done.. in all the terraform examples too
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
thanks @jamie! great summary
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
11:26 Pacific Daylight TimeWe have resumed webhook delivery and will continue to monitor as we process the backlog of events. <- github
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Ha, thanks Sorry @George I would give you more guidance on upgrade to 0.11, but 0.12 is a breaking change anyway and you might as well just rewrite your code once instead of twice.
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
You may also find there is very little to rewrite after the upgrade tool is out as well.
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"
I added a #atlantis channel since we’re doing a lot more with it these days (related to runatlantis.io).
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform module to send transactional emails via an SMTP server (e.g. mailgun) - cloudposse/terraform-null-smtp-mail
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hot off the press!
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Any plans to include that emailcli into packages?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Nvm @Erik Osterman (Cloud Posse) just seen https://github.com/cloudposse/packages/pull/95
what Add 12-factor style email cli why Easily send emails from command line or geodesic shell
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@vadzim can you review?
what Add 12-factor style email cli why Easily send emails from command line or geodesic shell
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
thanks @joshmyers!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
actually, we have a PR for it already - checking status
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yea, we’ll get that merged tomorrow probably
2018-10-23
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Given you can’t invoke modules with counts and TF isn’t an ideal language as yet, how do you see using/invoking that module? The example mentions creation of users, which I’d imagine is done as a list of vars. A module per user? I see other use cases but was interested in that as I have run into similar use case before.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i think we’re going to move away from the list-of-users model
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and instead do one tf file per user
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Agreed that would be more flexible at the moment although I’d hope 0.12 with hcl2 would improve that with rich data structures…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what Implement a terraform module that provisions an IAM user for humans with a login profile and encrypted password why Support operations by pull request to add users to AWS
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i’m getting this setup for our demo on thursday
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
IAM user account management with #atlantis
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Ahh, nice.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so, in this case, would invoke with each user.
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
I see how that all fits together now
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Nice way of doing it
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
what i don’t like is all the vars I have to pass related to smtp
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Modules all the way down
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
You could infer some of them if not otherwise provided, then again…HCL :(
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Also, I’m on mobile right now.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
heads up, v0.11.10 was just released and the download urls are different… they no longer have the v
in the version token… works:
• https://releases.hashicorp.com/terraform/0.11.10/terraform_0.11.10_linux_amd64.zip doesn’t work:
• https://releases.hashicorp.com/terraform/v0.11.10/terraform_v0.11.10_linux_amd64.zip
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@loren ugh, thanks for the heads up
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
sucks for our packaging system
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
wonder if that was deliberate on their behalf
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Seems like they’re saying that the prior working URLs were an accident? https://github.com/hashicorp/terraform/issues/19163#issuecomment-432310297
Terraform Version Terraform v0.11.9 + provider.archive v1.1.0 + provider.aws v1.41.0 + provider.null v1.0.0 + provider.random v2.0.0 + provider.template v1.0.0 + provider.tls v1.2.0 Expected Behavi…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Looks like we dodged the bullet on this one
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Cloud Posse installer and distribution of native apps, binaries and alpine packages - cloudposse/packages
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Nice. I don’t know how I managed to get the other URL into my configs. Blergh.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
luke - maintainer of #atlantis is joining HashiCorp to work fulltime on the project (announced at HashiConf)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
btw! if any of you are at hashiconf, reach out here! I know @antonbabenko is there
data:image/s3,"s3://crabby-images/dbcd5/dbcd587c3e2d0abf98b340377097a708d915ab49" alt="antonbabenko avatar"
Yes, I am inside the keynote room now
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
We will be live streaming Mitchell Hashimoto and Armon Dadgar’s opening morning keynote on Tuesday, October 23rd. The live stream will start at 9:30am PST and end at 11:00am PST.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hey Anton, how many people are there compared to Amsterdam ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform collaboration for everyone.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
State Storage, Locking, and History. No more state files! Automatically store and access state remotely whenever and wherever you run Terraform. State access is automatically locked during Terraform operations. In the UI, view a history of changes to the state, who made them, and when.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Today at HashiConf 2018 in San Francisco, we are announcing major updates across our entire suite of open source and enterprise products. Our mission…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
The Helm provider is used to deploy software packages in Kubernetes. The provider needs to be configured with the proper credentials before it can be used.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
I just discovered tfenv
- any good/bad experiences with this here? Seems like it is going to be useful with the new 0.12.x version coming up and working with “legacy” terraform.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
isn’t that in ruby?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hate to install that runtime just to switch envs in terraform
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
bash
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Terraform version manager. Contribute to Zordrak/tfenv development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
I think this is less of an issue when doing this all The Right Way™ (using container via geodesic)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i think tfenv
might be helpful initially
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
though i think there’s some way to specify the version compatibility
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
in fact things like this just reminds me I need to use geodesic everywhere
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
to support hcl 1 and 2
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Upgrading to Terraform v0.12
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i guess only one or the other will be supported
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
they recommend adding a version constraint on terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
just released https://github.com/cloudposse/terraform-aws-iam-user to manage IAM user account for humans
Terraform Module to provision a basic IAM user suitable for humans. - cloudposse/terraform-aws-iam-user
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it supports automatically associating the user with a list of groups as well as password generation using pgp+keybase
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
yea so the problem that led me to tfenv - was working with multiple repos/modules with different terraform version constraints
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
also - i was used to the rbenv
style of .terraform-version
in the root
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, given that - i think it’s probably the best alternative
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i can see where in long-lived environments that managing the terraform versions will be essential and risk to keep everything up to date perhaps
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
any project open on the new hcl migration? can probably help out with that if there’s a burn down list. (haven’t been following tf updates just know that was likely going to be released soonish)
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
or maybe just beta.. might try a couple just to dig into the new stuff. haven’t been deep in tf dev in a bit
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@jarv that would be HUGE
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
heh yeah you guy’s have a ton of modules.. was managing 50+ (over time) private repos at previous employer, didn’t have a lot of breaking tf changes during that time but can’t imagine it’s easy
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
was very close to going with cloudformation instead after hearing so many 0.6/0.7 horror stories
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, understand the temptation…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
in the end, would have just been trading pros/cons
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
yeah still do a fair bit of cloudformation when it makes sense, don’t mind it. service catalog support is pretty interesting, also if I can reuse any of the aws supported projects without tweaking much that’s a good tradeoff in a tf shop imo
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i think it’s still too early, but when the time comes, I’ll create a “Terraform Module Upgrade” project and add everything there.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
will announce that as soon as it’s there.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I can also help out, but have a few modules of my own to do first.. but happy to join forces for problem solving ofc.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Thanks guys! we’re going to need the help
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
whoaaaa … @Erik Osterman (Cloud Posse) you see Atlantis team is joining Hashicorp?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea! that’s both scary and exciting
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
ah thanks
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but yea, relevant here too
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i want to use atlantis for more than terraform
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but this doesn’t bode well for that roadmap
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
well now there’s github actions
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
waiting on invite
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
anyone already have access to github actions?
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
not yet - waiting as well
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
GitHub Actions vs. HashiCorp/Atlantis
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
~(possibly) Somewhat related:~oticed systems manager added a wait for user input action. unfamiliar with ssm but was curious if something like terraform ci was one of the use cases for adding thateh not sure that makes sense.. unsure why I was thinking about that now
data:image/s3,"s3://crabby-images/73a09/73a0957e4da2fb2c4c23648e3c70424f22148546" alt="jarv avatar"
guess I was probably thinking ssm because it manages (just?) os state.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Shall we create a 0.12 channel so problems & solutions don’t get lost in other talks ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I think it’s a good suggestion
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/41301/413016455f0fec21ed17a11f74585e772564c4a4" alt="Jeremy avatar"
Does anyone know of a way to provide multiple SSLCertificateArns for a beanstalk environment that is using an ALB? The name is called SSLCertificatesArns which implies that you can specify multiple arns but I have tried:
setting {
namespace = "aws:elbv2:listener:443"
name = "SSLCertificateArns"
value = "<someArnForFirstCert>"
}
setting {
namespace = "aws:elbv2:listener:443"
name = "SSLCertificateArns"
value = "<someArnForSecondCert>"
}
And also tried:
setting {
namespace = "aws:elbv2:listener:443"
name = "SSLCertificateArns"
value = "<someArnForFirstCert>,<someArnForSecondCert>"
}
And:
setting {
namespace = "aws:elbv2:listener:443"
name = "SSLCertificateArns"
value = ["<someArnForFirstCert>", "<someArnForSecondCert>"]
}
Neither of these approaches seems to work correctly and cannot find any other documentation on it other than: https://docs.aws.amazon.com/elasticbeanstalk/latest/dg/command-options-general.html#command-options-general-elbv2-listener
Configure globally available options for your Elastic Beanstalk environment.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Sorry - not sure how to do it, but if you figure it out and need to make some changes - we accept nearly all PRs
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Jeremy Looking at the Elastic Beanstalk Documentation it seems that Arns actually refer to just one ARN, maybe they wanted to be prepared future wise. Could you actually add multiple in the AWS Console ? As alternative you could create a new Certificate in ACM with support for multiple domain names, and have just one ARN.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform provider for checking out git repositories and making changes - Yelp/terraform-provider-gitfile
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cool idea - too bad not maintained
2018-10-24
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
Hi, I am looking for information on how to source passwords from azure keyvault using remote-exec(terraform). Basically I will have to copy a property file to the server which I will source it from git. I do not want the properties file to have sensitive information like secrets/ passwords. so I would want to append the file to password/secret’s from keyvault in azure platform
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
or either using cloud-init
can I use variable which will query keyvault?
data:image/s3,"s3://crabby-images/16cf1/16cf12bfaf7fe0b5c40dac4207a7ca03cd951fc7" alt="markmutti avatar"
@praveen Not able to use the native resource (https://www.terraform.io/docs/providers/azurerm/r/key_vault.html)?
Manages a Key Vault.
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
@Mark, yes I use key vault. But my question is if I can query keyvault by passing query keyvault variable in remote-exec or cloud-init
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@praveen what about giving the server access to that keyvault, and retrieve those values at boot ?
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
how can I do that. can I have any example if already done. I mean if there is any ref to git code
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I’m not an Azure expert, but maybe this can help you. https://github.com/sozercan/terraform-vm-keyvault/tree/ea67b8ca5eac82fd92bfe27f40bcf4ada565d93e
Microsoft Azure Linux VM created with Terraform that uses Azure Key Vault - sozercan/terraform-vm-keyvault
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
I will try this and let you know the result
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Could I get some reviews on this PR? https://github.com/EasterSealsBayArea/terraform-aws-elastic-beanstalk-environment/pull/1
It is a fork not going to our master yet (using gitflow; will test/validate it internally from the develop branch with our projects then commit back). I didn’t want to go straight to the official yet without giving it some solid testing.
Problem Add health log streaming to https://github.com/EasterSealsBayArea/terraform-aws-elastic-beanstalk-environment. Ensure log rotate exists. AWS docs: https://docs.aws.amazon.com/elasticbeansta…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@johncblandii don’t see anything controversial with the PR
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
to rebuild the readme run
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
make init
make readme
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i did the readme part but not init. will do that now. thx
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
oh, that’s the easier way to install everything.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
oh…maybe this is needed to be resolved for a full rebuild?
/bin/bash: gomplate: command not found
make: *** [readme/build] Error 127
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
1 sec
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
oh, looks like we’re missing a dep
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
you can run:
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
make packages/install/gomplate
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
ahh
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
pushed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make readme/deps
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i mistook docs/terraform.md
for the readme without even checking the filename
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
good to know @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
PR looks good to me
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
cool
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
will get it tested on our stuff then PR it to your upstream
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
a few other things will come soon too
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
sidebar: this .12 stuff in TF will clean up the env vars (for/foreach loops) and settings (null values) tremendously
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
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"
@johncblandii if you want to help us update the beanstalk module (when the time comes), we’d be grateful
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
absolutely, @Erik Osterman (Cloud Posse). going to do more updates to help out
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@johncblandii any reason you’re not using ECS or Kubernetes?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(we found beanstalk deployments to be more flakey in the long run, which is why we have moved to the other systems)
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
moving there. devops is a small team here so it comes down to time and we have the beanstalk stuff down
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
another quick and easy one https://github.com/EasterSealsBayArea/terraform-aws-elastic-beanstalk-environment/pull/2
Feature Some Beanstalk outputs were missing. Solution Added all available Beanstalk outputs.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
2018-10-25
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
a bit confused about what to expect of Terraform when using terraform-aws-ecs-web-app
. If a new task definition is created, should Terraform automatically redeploy the service with the new definition? I’m currently seeing the new definition show up, but just the old tasks remain running. I guess the question is, should aws ecs update-service
be necessary if my terraform-aws-ecs-web-app
is configured correctly?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
the terraform-aws-ecs-web-app
module is designed to work with CodeBuild/CodePipeline to automatically deploy changes merged to master.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this only works if you add a buildspec.yaml
to your projects
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"
so, to answer your quesiton, calling aws ecs update-service
is not needed if configured correctly
data:image/s3,"s3://crabby-images/5a9a1/5a9a1ed10aacb2436a164a64eaa88d0f55bde498" alt="dan avatar"
awesome, thanks for the quick help!
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
hope it helps!
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
How do you guys manage your multi-env settings? Currently we use terragrunt, but that’s going away.
I know we can do tfvar files, but is that the best way? I don’t want to end up doing tf plan -var-file=prod.tfvars
and tf plan -var-file=prod.tfvars -var-file=uswest2.tfvars
and so on and so forth to separate the vars for reuse across a lot of configs (4 app stages, multi-region, multi-account).
Thoughts?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @johncblandii, maybe you already saw that, but here is what we do:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Although there are many possible ways of doing that, we use containers + ENV vars
pattern.
As you mentioned, template rendering is another pattern (as implemented in terragrunt
).
We store the ENV vars in either AWS SSM (secrets) or in Dockerfiles (not secrets).
Here are more details:
-
We have a collection of reusable TF modules https://github.com/cloudposse/terraform-root-modules. The modules have no identity, everything is configurable via ENV vars. (In other words, they don’t care where they will be deployed and how).
-
We deploy each stage (root, prod, staging, dev, testing) in a separate AWS account for security and better management
-
For each AWS account/stage (root, prod, staging, dev, testing), we have a GitHub repo which is a container (for which we use
geodesic
https://github.com/cloudposse/geodesic):
https://github.com/cloudposse/root.cloudposse.co https://github.com/cloudposse/prod.cloudposse.co https://github.com/cloudposse/staging.cloudposse.co https://github.com/cloudposse/dev.cloudposse.co https://github.com/cloudposse/testing.cloudposse.co
Not secret ENV vars are defined in the Dockerfiles, e.g. https://github.com/cloudposse/prod.cloudposse.co/blob/master/Dockerfile#L17 In other words, the account containers have identity defined via the ENV vars.
-
https://github.com/cloudposse/terraform-root-modules is added to the containers https://github.com/cloudposse/prod.cloudposse.co/blob/master/Dockerfile#L36
-
Inside the containers, users assume IAM roles ro access the corresponding AWS account and then provision TF modules.
-
Inside the containers we use
chamber
(https://github.com/segmentio/chamber) to read secrets from SSM (per AWS account)
So when we run a container (e.g. prod
), we already have all ENV vars setup, and we read all the secrets from the account SSM store.
An account/stage can be in any region (also specified via ENV var, e.g. https://github.com/cloudposse/prod.cloudposse.co/blob/master/Dockerfile#L14)
Take a look at our docs for more details: https://docs.cloudposse.com/reference-architectures/ https://docs.cloudposse.com/reference-architectures/cold-start/ https://docs.cloudposse.com/reference-architectures/notes-on-multiple-aws-accounts/ https://docs.cloudposse.com/geodesic/
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
going to digest that a bit more but those *.cp repos are containers you run on prod or containers that deploy prod?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
thx for the docs. i’ll digest those as well
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
containers that you run on your local computer or on CI/CD
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
inside the containers you run diff commands to deploy TF, Helm, Helmfiles etc.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the containers have all ENV vars setup for a particular env (account/stage)
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
ok, i thought that’s what I was reading. interesting approach
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so to add new account/stage/env, you create a new GitHub repo with new container specific to that env
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and define specific ENV vars, and in the Dockerfile copy specific TF modules and helmfiles etc.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
good deal. hadn’t thought of that approach
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"
(other than docker)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
plus you have an immutable artifact that contains all the tools you need for that version of the infrastructure.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so we can use the same tools, processes we use to manage regular apps (e.g. nodejs apps, go apis, etc) with managing the infrastructure as code (terraform).
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if you don’t mind me asking, why is terragrunt going away?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
it is quite verbose when attempting to duplicate a project to another account or region
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
it is decent for the simple setup and useful for cascading tfvar values, but our directory structure is getting long in the tooth for 4 accounts and 1 region. if we go to 2 regions it’ll be unwieldy. I’m trying to get ahead of that curve
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Okay - would be happy to jump on a zoom screen share and show you how we do it.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
you use tg?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i’d love to do that, btw.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
or you mean show the above stuff?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Both actually :-)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
good deal. how much time should I select?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
went w/ 60. we may not need it but just in case
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
2018-10-26
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Hi all. I still trying to create/destroy beanstalk using
source = "git::<https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment.git?ref=tag/0.5.0>"
Option
force_destroy = true
But getting this
1 error(s) occurred:
* module.dev_front_end.module.logs.aws_s3_bucket.default (destroy): 1 error(s) occurred:
* aws_s3_bucket.default: error deleting S3 Bucket (develop-dev-front-dev-vitalii-logs): BucketNotEmpty: The bucket you tried to delete is not empty. You must delete all versions in the bucket.
status code: 409, request id: 01B995B9AA71BAC0, host id: KwxTu/DhRRig0CtYmdq0qokvgEgCGDeiUAUB2b4yQna9hmnzWieVdtcSi8aGzg6oF4mk5JRff2s=
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
What is wrong ?
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
Was the bucket created with force destroy set to true?
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
(I’m reading https://github.com/hashicorp/terraform/issues/7854 )
Terraform Version Terraform v0.6.16 Affected Resource(s) aws_s3_bucket Terraform Configuration Files resource "aws_s3_bucket" "storage" { bucket = "storage.${var.dns_zone}&…
data:image/s3,"s3://crabby-images/edb91/edb91a4755d8fc41d38fa206176ab081bb6f27f7" alt="George avatar"
(Also https://stackoverflow.com/questions/49611774/aws-s3-bucket-delete-issue ) last comment mentions lifecycle policy, maybe check that too
I am deleting bucket from AWS S3 and versioning is enabled, but it’s showing this error: aws_s3_bucket.bucket: Error deleting S3 Bucket: BucketNotEmpty: The bucket you tried to delete is not emp…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea if the bucket was created without force_destroy = true
and it was added later, it will not be force destroyed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
try to apply again and then destroy
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or destroy manually and then apply with force destroy
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but looks like the issue is still not solved or just does not work in some cases https://github.com/terraform-providers/terraform-provider-aws/issues/208
This issue was originally opened by @osterman as hashicorp/terraform#7854. It was migrated here as part of the provider split. The original body of the issue is below. Terraform Version Terraform v…
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Yes bucket was created with force_destroy
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Can I prevent creating bucket for logs ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not in the current version. If you open a PR, we’ll review it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
need to add a var elb_logs_enabled
and then add count
here https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L990
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
resource "aws_s3_bucket" "elb_logs" {
count = "${var.elb_logs_ebnabled == "true" ? 1: 0}"
bucket = "${module.label.id}-logs"
acl = "private"
force_destroy = "${var.force_destroy}"
policy = "${data.aws_iam_policy_document.elb_logs.json}"
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then update here https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L557
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and here https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L561
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Configure globally available options for your Elastic Beanstalk environment.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I’m fighting the beanstalk env with a silly error about the label. I passed in tags, didn’t pass tags, etc and it keeps giving me fits.
module.sc-api-env-active.module.elastic_beanstalk_environment.module.label.data.null_data_source.tags_as_list_of_maps: data.null_data_source.tags_as_list_of_maps: value of 'count' cannot be computed
Version:
source = "[email protected]:cloudposse/terraform-aws-elastic-beanstalk-environment.git?ref=0.5.0"
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
any thoughts?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok, this is the problem https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L3
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
yeah
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the latest versions of null-label
added a lot of stuff, but it breaks in complex configurations
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i saw the new stuff in there
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
it got complex pretty quickly
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so we need to change it to ref=tags/0.3.3
which does not have all that stuff and was working
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform Module to define a consistent naming convention by (namespace, stage, name, [attributes]) - cloudposse/terraform-terraform-label
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
want to open a PR?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
sure. which do you prefer? moving the version back or changing the source?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
let’s use the latest of git://github.com/cloudposse/terraform-terraform-label.git?ref=tags/0.1.6>
Terraform Module to define a consistent naming convention by (namespace, stage, name, [attributes]) - cloudposse/terraform-terraform-label
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we’ll fix the null-label
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(simplify it)
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
cool. PR incoming in a sec
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
testing
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Problem The terraform-null-label grew a bit complex and is throwing errors when used: * module.sc-api-env-active.module.elastic_beanstalk_environment.module.label.data.null_data_source.tags_as_list…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
tested?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
about to test on my module
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i tested in the example
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Switched to source = "[email protected]:eastersealsbayarea/terraform-aws-elastic-beanstalk-environment.git?ref=53c5aa8"
Plan: 48 to add, 0 to change, 0 to destroy.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok thanks, will merge
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
coolio
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
sweet. thx
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
new release https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/releases/tag/0.6.1
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
have you guys seen an attribute listed in docs but error as an unavailable attribute?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
docs clearly say description
is an attribute, but it isn’t working when output: https://www.terraform.io/docs/providers/aws/r/elastic_beanstalk_environment.html#description-1
Provides an Elastic Beanstalk Environment Resource
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hmm, we saw something like that for other modules, but not in EB
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
testing stuff locally
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
could be some cache issue. it works when i reference the local module
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
removed it
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
PR for merge to master: https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/pull/57
Features EasterSealsBayArea#3 EasterSealsBayArea#2 EasterSealsBayArea#1 Testing Update examples/complete/main.tf’s source to ../../ Plan it Verify the plan completes successfully
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
pushed a documentation fix
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
test results added
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"
@johncblandii the PR looks good, thanks, just one comment
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
cool. checking
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
pushed
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
terraform fmt
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
please run
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
ugh…meant to do that
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i turned off auto-format in VS
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
it made me lazy to formatting.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks
2018-10-27
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
If any gophers or terraform provider authors are around and have some free time - could use a review: https://github.com/terraform-providers/terraform-provider-pagerduty/pull/99
This fixes #97, instantiating scheduled actions if use_support_hours incident urgency type is set. It ensures that the pagerduty API calls will include an empty scheduled_actions in certain cases, …
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
whoa! terraform fmt github action: https://www.terraform.io/docs/github-actions/actions/fmt.html
Terraform by HashiCorp
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
/cc @Andriy Knysh (Cloud Posse)
Terraform by HashiCorp
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Haha, I knew that :). Thanks
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
I keep forgetting this is still closed beta , just checked I don’t have access yet - did you manage to get an invite?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
No not yet
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@sarkis the PR looks OK to me (as far as I can tel w/o testing anything )
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Thanks for looking @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this does exactly what atlantis
does https://www.terraform.io/docs/github-actions/actions/plan.html
Terraform by HashiCorp
2018-10-29
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Hi again. I’m still fighting with getting beanstalk and rds work together. Need some help here please:
module "elastic_beanstalk_environment" {
source = "git::<https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment.git?ref=tag/0.6.2>"
namespace = "${var.namespace}"
stage = "${var.environment}"
name = "${var.user_account_name}"
zone_id = "${var.parent_zone_id}"
app = "${module.elastic_beanstalk_application.app_name}"
# associate_public_ip_address = false
instance_type = "${var.instance_type}"
autoscale_min = 1
autoscale_max = 4
updating_min_in_service = 0
updating_max_batch = 1
autoscale_lower_bound = 20
autoscale_upper_bound = 80
updating_max_batch = 1
updating_min_in_service = 1
wait_for_ready_timeout = "20m"
loadbalancer_type = "application"
vpc_id = "${module.vpc.vpc_id}"
public_subnets = "${module.subnets.public_subnet_ids}"
private_subnets = "${module.subnets.private_subnet_ids}"
security_groups = ["${module.vpc.vpc_default_security_group_id}"]
solution_stack_name = "64bit Amazon Linux 2018.03 v4.5.3 running Node.js"
tier = "WebServer"
force_destroy = true
keypair = "${aws_key_pair.dev_ssh_key.key_name}"
ssh_listener_enabled = true
ssh_listener_port = "22"
ssh_source_restriction = "0.0.0.0/0"
http_listener_enabled = true ## Enable port 80 (http)
# instance_refresh_enabled = true ## Enable weekly instance replacement.
update_level = "minor" ## The highest level of update to apply with managed platform updates
preferred_start_time = "Sun:10:00"
rolling_update_type = "Health"
root_volume_size = "10"
root_volume_type = "gp2"
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_USERNAME"
value = "${rds_instance.default.database_user}"
}
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_PASSWORD"
value = "${rds_instance.default.database_password}"
}
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_DATABASE"
value = "${rds_instance.default.name}"
}
setting {
namespace = "aws:elasticbeanstalk:application:environment"
name = "RDS_HOSTNAME"
value = "${rds_instance.default.instance_endpoint}"
}
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
and RDS
module "rds_instance" {
source = "git::<https://github.com/cloudposse/terraform-aws-rds.git?ref=tag/0.4.1>"
namespace = "${var.namespace}"
stage = "${var.environment}"
name = "${var.user_account_name}-db"
dns_zone_id = "${var.parent_zone_id}"
host_name = "db"
dns_zone_id = "${var.parent_zone_id}"
security_group_ids = ["${module.vpc.vpc_default_security_group_id}"]
database_name = "app_db"
database_user = "dbuser"
database_password = "password"
database_port = 5432
multi_az = "false"
storage_type = "gp2"
allocated_storage = "5"
storage_encrypted = "false"
engine = "postgres"
engine_version = "9.6.6"
instance_class = "db.t2.micro"
db_parameter_group = "postgres9.6"
#parameter_group_name = "mysql-5-7"
publicly_accessible = "false"
subnet_ids = ["${module.subnets.public_subnet_ids}"]
vpc_id = "${module.vpc.vpc_id}"
auto_minor_version_upgrade = "true"
allow_major_version_upgrade = "false"
apply_immediately = "false"
maintenance_window = "Mon:03:00-Mon:04:00"
skip_final_snapshot = "true"
copy_tags_to_snapshot = "true"
backup_retention_period = 7
backup_window = "22:00-03:00"
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Getting
Error: module 'elastic_beanstalk_environment': unknown resource 'rds_instance.default' referenced in variable rds_instance.default.database_user
Error: module 'elastic_beanstalk_environment': unknown resource 'rds_instance.default' referenced in variable rds_instance.default.database_password
Error: module 'elastic_beanstalk_environment': unknown resource 'rds_instance.default' referenced in variable rds_instance.default.instance_endpoint
Error: module 'elastic_beanstalk_environment': unknown resource 'rds_instance.default' referenced in variable rds_instance.default.name
Error: module "elastic_beanstalk_environment": "setting" is not a valid argument
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
what I’m doing wrong
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @bober2000
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so let’s see here
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
I’ve found that I missed value = “${module.rds_instance.database_user}”
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
first, fix the errors in referencing the module value = "${module.rds_instance.default.instance_endpoint}"
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
but now I’m getting only Error: module “elastic_beanstalk_environment”: “setting” is not a valid argument
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(add module...
in front)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok, to provide ENV vars to the elastic beanstalk module, use it like this https://github.com/cloudposse/terraform-aws-jenkins/blob/master/main.tf#L49
Terraform module to build Docker image with Jenkins, save it to an ECR repo, and deploy to Elastic Beanstalk running Docker stack - cloudposse/terraform-aws-jenkins
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Let me try this
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(setting
is not a valid argument b/c it’s not exposed as var in the current release of the module. We have some PRs and issues opened to do it, we’ll look into that since it would fix some other issues)
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
added
env_vars = "${
merge(
map("RDS_HOSTNAME","${module.rds_instance.instance_endpoint}",
"RDS_USERNAME","${module.rds_instance.database_user}",
"RDS_PASSWORD","${module.rds_instance.database_password}",
"RDS_DATABASE","${module.rds_instance.name}"
), env_vars
)
}"
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Now getting Error: module ‘elastic_beanstalk_environment’: “database_user” is not a valid output for module “rds_instance” Error: module ‘elastic_beanstalk_environment’: “name” is not a valid output for module “rds_instance” Error: module ‘elastic_beanstalk_environment’: “database_password” is not a valid output for module “rds_instance
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Have separate
env_vars
defined previously to set some app staff
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
env_vars = "${
map(
"environment", "${var.environment}",
"namespace", "${var.namespace}",
"user", "${var.user_account_name}",
"API_HOST", "${var.api_host}",
...
)
}"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
here are the outputs from the RDS module https://github.com/cloudposse/terraform-aws-rds/blob/master/outputs.tf
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
HM, than how could I get all staff to connect my app to RDS DB ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
database_user
and database_password
you already know when providing them here https://github.com/cloudposse/terraform-aws-rds/blob/master/variables.tf#L44`
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so you need user and password (which you know and you provide them to the RDS module and to the EB module as ENV vars)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then you need endpoint https://github.com/cloudposse/terraform-aws-rds/blob/master/outputs.tf#L11
Terraform module to provision AWS RDS instances. Contribute to cloudposse/terraform-aws-rds development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
My fault
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Thanks for help - all clear now
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
nice
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then in you app (e.g. NodeJs), you use those ENV vars, like this:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
function getDbSettings() {
return (
{
host: process.env.DB_HOST,
database: process.env.DB_NAME,
user: process.env.DB_USER,
password: process.env.DB_PASSWORD
});
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so you need 4 ENV vars
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
env_vars = "${
map(
"DB_HOST", ""${module.rds_instance.instance_endpoint}",
"DB_NAME", "xxxxxxxx",
"DB_USER", "xxxxxxxxxx",
"DB_PASSWORD", "xxxxxxxxx",
)
}"
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Quick question
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
could password be autogenerated ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it could be, it’s outside the module anyway
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and you can use any script to autogenerate it, even TF like this https://www.terraform.io/docs/providers/random/index.html
The Random provider is used to generate randomness.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
How could I incert it in DB_PASSWORD ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Produces a random string of a length using alphanumeric characters and optionally special characters.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
resource "random_string" "password" {
length = 16
special = true
override_special = "/@\" "
}
module "rds_instance" {
source = "git::<https://github.com/cloudposse/terraform-aws-rds.git?ref=tag/0.4.1>"
namespace = "${var.namespace}"
stage = "${var.environment}"
name = "${var.user_account_name}-db"
dns_zone_id = "${var.parent_zone_id}"
host_name = "db"
dns_zone_id = "${var.parent_zone_id}"
security_group_ids = ["${module.vpc.vpc_default_security_group_id}"]
database_name = "app_db"
database_user = "dbuser"
database_password = "${random_string.password.result}"
....
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
And than use the same
"DB_PASSWORD", "${random_string.password.result}"
in setting envs ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Yes
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Thanks for help. Will try to contribute to code next week
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
hi I am a newbie on terraform, and got a good amount of AWS experience.. I want to know how to start scripting in terraform
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Welcome @ALI
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Probably take a look at some modules
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
thanks @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
yea I am looking at some of the modules .
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
What AWS resources do you want to script?
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
I want to script on VPC, EC2 ,Dynamo DB
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
for now
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
We have that :)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Give me a few minutes
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
sure!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module that implements AWS DynamoDB with support for AutoScaling - cloudposse/terraform-aws-dynamodb
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform Module that defines a VPC with public/private subnets across multiple AZs with Internet Gateways - cloudposse/terraform-aws-vpc
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform Module for providing a general EC2 instance provisioned by Ansible - cloudposse/terraform-aws-ec2-instance
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform Module for providing a EC2 instance capable of running admin tasks and provisioned by Ansible - cloudposse/terraform-aws-ec2-admin-server
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform Module for provisioning multiple general purpose EC2 hosts for stateful applications. - cloudposse/terraform-aws-ec2-instance-group
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@ALI take a look at these modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
usage example https://github.com/cloudposse/terraform-root-modules/blob/master/aws/backing-services/vpc.tf
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"
At first it might be daunting but itll get easier
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
let us know if any questions
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
thanks @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
haha I will take that @pericdaniel
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@ALI you’ve signed up for a master class in terraform
data:image/s3,"s3://crabby-images/1e55e/1e55e3b3b2c9a77fa8da481c723b78a660362f65" alt="ALI avatar"
I bet @Erik Osterman (Cloud Posse), @Andriy Knysh (Cloud Posse) I will if I am stuck anywhere ..
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
How do we all handle modelling the infrastructure within accounts in multi-account architectures? Do you have a declarative file that lists all of it? Some of it? Or do you bundle it all per project and just rely on the knowledge of the team to know what’s live?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Dombo are you referring to our reference architectures or asking generally?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Generally - but also reference arch if you want to talk in terms of that
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
I’m interested in how others handle this - I don’t see many mature IaC code bases
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
There are some things that are persistent and not tied to apps like management servers, bastions, VPCs, sec groups, IAM roles/policies/users
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
These are genreally per account
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Agreed - this is how we deploy them
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Then there are application specfiic deployment dependencies
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We have been deploying this stuff along side the other platform related services in the account repos. However, we’re in the early stages of using #atlantis to enable applications to have their own terraform/
folder, which defines their dependencies.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
e.g. if a microservice needs an RDS database, it should be able to define it near the app itself, which out defining it in the account repos.
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
I wonder if you treat them the same or differently?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Common modules folder + declarative master stack/.tf file per account + .tf file per project? Where do you track state in both cases? Other ways of tackling this?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
So we publish all of our reference architectures here: https://cpco.io/reference-architectures
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
high-level, we have one repo (terraform-root-modules
) which contain the “root level” terraform module invocations
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
then we have one repo per AWS account. This allows us to easily keep stages separately, but also reuse code between stages in the form of modules.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
(@Andriy Knysh (Cloud Posse) re-share that thread)
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Andriy explained it pretty well in this thread: https://sweetops.slack.com/archives/CB6GHNLG0/p1540514525000100
Although there are many possible ways of doing that, we use containers + ENV vars
pattern.
As you mentioned, template rendering is another pattern (as implemented in terragrunt
).
We store the ENV vars in either AWS SSM (secrets) or in Dockerfiles (not secrets).
Here are more details:
-
We have a collection of reusable TF modules https://github.com/cloudposse/terraform-root-modules. The modules have no identity, everything is configurable via ENV vars. (In other words, they don’t care where they will be deployed and how).
-
We deploy each stage (root, prod, staging, dev, testing) in a separate AWS account for security and better management
-
For each AWS account/stage (root, prod, staging, dev, testing), we have a GitHub repo which is a container (for which we use
geodesic
https://github.com/cloudposse/geodesic):
https://github.com/cloudposse/root.cloudposse.co https://github.com/cloudposse/prod.cloudposse.co https://github.com/cloudposse/staging.cloudposse.co https://github.com/cloudposse/dev.cloudposse.co https://github.com/cloudposse/testing.cloudposse.co
Not secret ENV vars are defined in the Dockerfiles, e.g. https://github.com/cloudposse/prod.cloudposse.co/blob/master/Dockerfile#L17 In other words, the account containers have identity defined via the ENV vars.
-
https://github.com/cloudposse/terraform-root-modules is added to the containers https://github.com/cloudposse/prod.cloudposse.co/blob/master/Dockerfile#L36
-
Inside the containers, users assume IAM roles ro access the corresponding AWS account and then provision TF modules.
-
Inside the containers we use
chamber
(https://github.com/segmentio/chamber) to read secrets from SSM (per AWS account)
So when we run a container (e.g. prod
), we already have all ENV vars setup, and we read all the secrets from the account SSM store.
An account/stage can be in any region (also specified via ENV var, e.g. https://github.com/cloudposse/prod.cloudposse.co/blob/master/Dockerfile#L14)
Take a look at our docs for more details: https://docs.cloudposse.com/reference-architectures/ https://docs.cloudposse.com/reference-architectures/cold-start/ https://docs.cloudposse.com/reference-architectures/notes-on-multiple-aws-accounts/ https://docs.cloudposse.com/geodesic/
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @Erik Osterman (Cloud Posse)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so yea, the main idea is when a user logs into an account from a geodesic
module (let’s say staging
), they can’t see and do any damage (even accidentally) to other accounts (root
, prod
, etc.) - completely separated
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Of course - I also practice account separation iwth about 15-20 accounts implemented in my org.
Some interesting patterns described in that thread. What do you do about provisioning IAM users/tfstate backing resources?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Bootstrap 0 if you will
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
If this is documented somewhere feel free to point me there
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
I know you guys aren’t just here to answer q;s
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’re not optimizing for the coldstart right now - as in one command to spin up 20 accounts
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
namely the problem is an order of operations that needs to be performed that terraform is not well suited for, especially if there are any cycles in the graph
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
some of it could be optimized using terragrunt, however, customers seldom if ever start over from scratch again from bootstrap 0
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we also provision one state bucket per account, rather than a centralized state bucket
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this is just sticking with our “share nothing” approach, which also convolutes the process of bootstrapping
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Interesting choice regarding one bucket/dynamo table per account - is there a reason why?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
share nothing
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
so for example, if you share the state bucket, there’s no way to stage changes to the statebucket without if affecting all stages all at once
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Hmmm good point
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but by allowing each stage/account to have their own bucket, they are entirely standalone
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea, and we do provision accounts and add users to roles
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/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/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Powerful way of doing it
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Impressed - kudos
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
problem with it is terraform seems to be nudging people to a single shared state bucket
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and using workspaces
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we don’t use terraform workspaces
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Yeah neither do I - not a fan for reasons
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
terraform is also coming out with “managed state as a service” free for all
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
curious to see how that works and fits in
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Yeah that’s off the back of the atlantis acquisition I presume
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
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"
i don’t think it’s related persay, but to your point atlantis is big on workspaces
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
and aligned therefore with their trajectory.
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Doesn’t have to be though - pretty sure you can define the lifecycle as you wish with custom workflows and such
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we have it working without it
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
At which point it could compliment your guys system quite nicely
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
are you using terragrunt?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Collaborative plan & release to certain stages
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
terragrunt at work
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
cool
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
atlantis + similar system to yours when consulting in Aus
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
have you seen our fork of atlantis?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Yeah I did
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Just so you could add your own name?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
hahaha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
actually, have zero interest in maintaining it
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
I wish I could hard fork alexa & google assistant for the same reason
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
just it’s very hard to get features accepted into atlantis right now
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but luke hears our requests loud and clear and is working to incorporate them
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Yeah I guess that’s them signalling the future of the project?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
My bet is EOL and roll internal to Hashi
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
heh
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
are you excited about GitHub actions?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Reasonably - lots of my customers are on Bitbucket/Gitlab/Self hosted stuff
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
I’m curious to see how it plays out in the community
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Actions are a direct shot at the best monetised section of githubs partner ecosystem
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yes, to a degree
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
or it could also be seen as a way of allowing them to have tighter integration with GitHub
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
i see actions evolving into something like Salesforce for GitHub
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Yeah I’d be interested to see how that integration goes down
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Good to meet some other people pushing the limits of the modern IAC toolchain
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Even if you are on the other side of the world
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
thanks!! you’re among friends
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Anyway it’s the middle of the day over here
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
Gotta get back to work
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ttyl
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Dombo I forgot where you are located?
data:image/s3,"s3://crabby-images/bf671/bf6712d8170e997d69171303e63dfeaf5479d893" alt="Dombo avatar"
2018-10-30
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Hi, if using terraform-aws-dynamic-subnets what Actions should I allow in policy to make it work? Creating separate user for terraform now and trying to limit access
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Now getting
module.subnets.aws_eip.default[0]: aws_eip.default.0: UnauthorizedOperation: You are not authorized to perform this operation.
on apply
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@bober2000 The same logic to Terraform applies to general AWS usage. Limiting the Terraform user is generally not making things easier.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
@maarten is there any kind of recommendations to read? Idea is to give developers terraform files so they could spin up envs for usage - so I don’t want them to create or destroy something with admin access
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
sure, one moment
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Account-level considerations, best practices, and high-level strategic guidance to help structure and manage multiple AWS accounts for security purposes
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Most companies do this adding AWS accounts for different purposes like testing.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Thanks a lot.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Sure man, good luck
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
After reading those article I see that I really need it…
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
this isn’t sweetops specific, but hoping someone here can give me some insight. I’m using resource “aws_iam_user_policy” and getting a limit error “Error putting IAM user policy CloudCheckr_RO: LimitExceeded: Maximum policy size of 2048” when running terraform apply. But I can create this policy just fine in the console
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @shaiss
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
Hi @Andriy Knysh (Cloud Posse) looks like it’s an AWS limit https://docs.aws.amazon.com/IAM/latest/UserGuide/reference_iam-limits.html. odd that it works in the console though
Describes the maximum number, size, and name limits of entities such as users, groups, roles, policies, keys, certificates, and MFA devices in AWS Identity and Access Management (IAM).
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you create exactly the same policy in the console?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s better not to attach policies to individual users
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
use groups instead
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
yes, I’m aware, this a requirment of a customer
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the limit for a group is higher
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Or create a customer managed policy and attach that one.
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
yes, that will be my suggestion to them again, but they claim they don’t need to b/c they can create that policy in the console
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea, we can create everything in the console
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Maybe Terraform has pre-flight checks which aren’t valid, or calculates differently from AWS.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Like AWS does not count spaces of the document and Terraform does.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
IAM does not count white space when calculating the size of a policy against these limitations
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
seems like the policy is 6850 bytes, or 4230 if ignore whitespaces
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
so either way, it should technically fail since it’s over the 2048 limit
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Where did you read that ?
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"
so maybe you could break it into a few aws_iam_user_policy(s)
@shaiss
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
@Andriy Knysh (Cloud Posse) yeah, that’s a good option!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
or
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
take this as input for your iam_user_policy “${replace(data.template_file.init.rendered,”/\s/”,”” )}”
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
@maarten sorry, not sure I’m following. atm, I’m going to try creating the policy as an IAM policy vs the iam_user_policy, then attaching it to the user, we’ll see if that works
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
sure, what ever works for you.
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
ha, that worked
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
I agree not the best way to do it, but it worked, and it’ll have to do for now
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
what did you try now ?
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
@maarten I created the user, created the iam policy, then attached the iam policy to the user. b/c it’s a generic iam policy and not a user policy, that limit doesn’t imply
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
*apply
data:image/s3,"s3://crabby-images/d29ec/d29ecada510c7d66399d67f9c668172c3a549efe" alt="shaiss avatar"
Anyone here using terraform w/ a marketplace ami? Seems like you have to use the we console to subscribe to the marketplace item first b4 you can call it from TF
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Yes that’s correct. We use terraform with pfSense firewall Ami from market place
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I believe we first had to activate the subscription
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We didn’t attempt to automate market place subscriptions. This was more than a year ago. Not sure if it is possible.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
hi, any plans to add support for ssl negotiating policy to the terraform-aws-elastic-beanstalk-environment module? (https://www.terraform.io/docs/providers/aws/r/lb_ssl_negotiation_policy.html)
Provides a load balancer SSL negotiation policy, which allows an ELB to control which ciphers and protocols are supported during SSL negotiations between a client and a load balancer.
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
or to specify an existing aws policy?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@i5okie if you open a PR, we’ll promptly review
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks
data:image/s3,"s3://crabby-images/e3fa1/e3fa1aafa7df1696ca608d23955db9828d708f1c" alt="i5okie avatar"
alrighty. was just wondering. thanks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thank you for pointing that out, nice addition to the module
2018-10-31
data:image/s3,"s3://crabby-images/5a049/5a049607b884ec68b05d5fd74af63f27fc7aeaa9" alt="Kenny Inggs avatar"
I have a question related to https://github.com/cloudposse/terraform-aws-route53-cluster-zone. How do you deal with the “production” stage + zones? Typically, I’d have a zone for “dev” (e.g. dev.example.com, containing e.g. api.dev.example.com), and have the prod zone on the apex (example.com containing e.g. api.example.com). I’m wondering whether you guys do something like creating a prod.example.com zone, with Alias in the parent / apex zone? Or how else do you deal with the prod stage to apex mapping?
Terraform module to easily define consistent cluster domains on Route53 (e.g. [prod.ourcompany.com](http://prod.ourcompany.com)
) - cloudposse/terraform-aws-route53-cluster-zone
data:image/s3,"s3://crabby-images/5a049/5a049607b884ec68b05d5fd74af63f27fc7aeaa9" alt="Kenny Inggs avatar"
(this is particularly relevant on public, customer facing URLs in the prod zone. where you don’t want them to see prod. in every URL. Like websites or public API endpoints)
data:image/s3,"s3://crabby-images/5a049/5a049607b884ec68b05d5fd74af63f27fc7aeaa9" alt="Kenny Inggs avatar"
p.s. I also typically have a “global” stage or something similar that will have my MX, SPF and DKIM records.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Hi all
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Having problems on terraform init
Error downloading modules: Error loading modules: error downloading '<https://github.com/cloudposse/terraform-aws-s3-website.git?ref=tag/0.5.3>': /usr/bin/git exited with 1: error: pathspec 'tag/0.5.3' did not match any file(s) known to git.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
How to correctly set revision ?
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
source = "git::<https://github.com/cloudposse/terraform-aws-dynamic-subnets.git?ref=tag/0.3.7>"
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
or
source = "github.com/cloudposse/terraform-aws-dynamic-subnets/releases/tag/0.3.7"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Kenny Inggs it’s depends on a use case and a customer. We usually have two cases here:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Use subdomains for stages (prod.example.net, staging.example.net), and use an alias or CNAME from the public domain (e.g. example.com) to the prod stage (CNAME prod.example.net for example.com)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- The same as #1, but using diff TLDs for stages, e.g.
[example.net](http://example.net)
forprod
and[example.qa](http://example.qa)
forstaging
. Then CNAME for[example.com](http://example.com)
pointing to[example.net](http://example.net)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
all MX, SPF and DKIM records are in the global/public
domain
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@bober2000 we alwayd use tags like this https://github.com/cloudposse/terraform-aws-s3-website/blob/master/main.tf#L13
Terraform Module for Creating S3 backed Websites and Route53 DNS - cloudposse/terraform-aws-s3-website
data:image/s3,"s3://crabby-images/5a049/5a049607b884ec68b05d5fd74af63f27fc7aeaa9" alt="Kenny Inggs avatar"
Awesome. Thanks @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
np
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@bober2000 are you missing git::
in front of <https://github.com/cloudposse/terraform-aws-s3-website?ref=tag/0.5.3>
?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if not, maybe some DNS or caching issues on you computer
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
@Andriy Knysh (Cloud Posse) according to https://www.terraform.io/docs/modules/sources.html#github for github git:: could be missed
The source argument within a module block specifies the location of the source code of a child module.
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
about DNS or caching - we tried this on two PCs in Ukraine and in Germany
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
can you try adding git::
and test again?
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
It was there from beginning
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
removed .terraform and tried again
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
get this
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
try tags/0.5.3 with an S not just tag?
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
<https://github.com/cloudposse/terraform-aws-s3-website?ref=tags/0.5.3>
Terraform Module for Creating S3 backed Websites and Route53 DNS - cloudposse/terraform-aws-s3-website
data:image/s3,"s3://crabby-images/53074/53074d9f1945ce6d0ce0b66daa2a89a281492f10" alt="Andy avatar"
yup @bober2000 I just tried without the s and received the same error
data:image/s3,"s3://crabby-images/12941/129419cc8d17b3363c20e1c25ecac23362168d86" alt="bober2000 avatar"
Nice catch! @Andy you saved me!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ah yea :slightly_smiling_face: no s
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks @Andy
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
just toying with you guys terraform for creating VPCs.. any suggestions on where to start?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hey @nukepuppy
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform Module that defines a VPC with public/private subnets across multiple AZs with Internet Gateways - cloudposse/terraform-aws-vpc
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
example here https://github.com/cloudposse/terraform-root-modules/blob/master/aws/backing-services/vpc.tf
Collection of Terraform root module invocations for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i been messing with dynamic subnets.. its neat.. though it insists on cutting up a VPC in an odd way
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
like a /24 vpc into 4 /28s instead of 4 /26s when giving 2 azs priv/pub was odd.. was trying to see how to force that if even possible
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
there are many ways of cutting up a VPC
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
im getting the gist of it.. really cool collection of stuff you guys going
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we have a few diff modules for that
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for multi-AZ public and private subnets provisioning - cloudposse/terraform-aws-multi-az-subnets
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i love the uber high re-use of these
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for named subnets provisioning. Contribute to cloudposse/terraform-aws-named-subnets development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
so i just want my /24 into 2 AZs priv/pub as /26s what would be your recommendation on which one to try out?
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
actually.. terraform-aws-multi-az-subnets is one im trying now
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can specify any number of subnets you need
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
ooh so i assume if the value isnt set.. it uses AZ count as the subnet count maybe?
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i didnt look that deep into it yet ..
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, if not set, it uses all AZs
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
ah i had done this ` availability_zones = [“us-east-1a”, “us-east-1c”]`
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
and it did make 4 subnets.. but still cut up into /28s
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
making me only have 10ips in each hehe
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
try to set max_subnet_count
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it should divide correctly
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
or maybe this will be better for your use-case https://github.com/cloudposse/terraform-aws-multi-az-subnets#usage
Terraform module for multi-AZ public and private subnets provisioning - cloudposse/terraform-aws-multi-az-subnets
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
hm still did /28s
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
Terraform module for multi-AZ public and private subnets provisioning - cloudposse/terraform-aws-multi-az-subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since you provide CIDR blocks
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
is what im using as an example.. and modifying appropriately
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
im using the usage.. modified the AZ lists per pub/priv to just 2 AZs set.. az nat gw to 2
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
setup variables to be some of the usual stuff /namespace/app etc
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
cidr block set to a /24 but still get a /28 cut up
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok try to set this https://github.com/cloudposse/terraform-aws-multi-az-subnets/blob/master/variables.tf#L40
Terraform module for multi-AZ public and private subnets provisioning - cloudposse/terraform-aws-multi-az-subnets
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
private_az_subnet_ids = {
us-east-1a = subnet-xxxxx
us-east-1c = subnet-xxxxx
}
public_az_subnet_ids = {
us-east-1a = subnet-xxxxx
us-east-1c = subnet-xxxxx
}
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
let me have a look
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
oh hmm different format of max_subnets o.O
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you need any changes to the subnet modules to accommodate your requirements, please open a PR
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
oh hmm.. still cut into /28s despite having that var set
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
yeah ill have a look..
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i mean terraform vpc there is bazillion templates
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i just liked the idea of minimal go for re-use
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
its probably very useful for most normal larger VPCs but smaller ones may just be a bit too much?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea it’s not easy to come up with a universal module to create subnets, too many possible ways of doing it
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for our usage, the three modules were enough
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
yeah its doing 99% of everything id want it to do
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
except.. cut up the /24 into 4 /26s instead of /28s
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the calculations are here
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for multi-AZ public and private subnets provisioning - cloudposse/terraform-aws-multi-az-subnets
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
legit just trying to make this cut: http://jodies.de/ipcalc?host=10.147.223.0&mask1=24&mask2=26
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module for multi-AZ public and private subnets provisioning - cloudposse/terraform-aws-multi-az-subnets
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(been long time since we reviewed that)
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
thanks again @Andriy Knysh (Cloud Posse)… ill re-evaluate some other time.. i have this working in terraform i built by hand.. just wanted to give something shinier a whirl
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@nukepuppy outsider question, why do you want to have something smaller than a /24 when you have a /8 at disposal ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yea that’s why we did not pay much attention to how /8 was divided
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
@maarten because when you own IP space that must be routable between things and use IPAM at enterprise level
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
smaller VPCs are created for specific purposes..
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
and multi- account (aws) strategies become a bigger thing
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
no one should or would cut up a /8 into 1 VPC in aws i hope and run a company out of it
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
use about 20-30 aws accounts for stag and 25ish for prod
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
and all have different use cases / purposes
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
and different peering requirements
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
so.. its always viable
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
but a /24 for an individual person.. to use in multiple subnets in a VPC
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
seems pretty much a normal use case to me
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Wow, those are a lot of accounts per stack. Using /16 per vpc/account ourselves, I guess you have a lot of different teams/apps then
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
yes a lot… quite a lot
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
but in general wanted to just “can” as in soup.. the process of getting smaller stuff without everyone re-writing stuff ya know
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
all good .. very cool to see
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i was just building a small VPC for a specific reason and had a /24 available to toy with
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Thanks for explaining the use-case. I know someone who works at a company which makes route planning sw for cars .. the sheer size of different aws/azure accounts is just mindblowing.
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
oh right thats other thing the /8 has multi cloud uses etc etc.. so getting a small cut etc is usually something like a /20 for a team until its used up
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
and from that /20 you cut up what you can
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
but even then a class C VPC can host a bunch of things ya know
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
True, but on the other hand, if you divide a /8 in /16’s you have 255 VPC’s. If the company can’t fit inside 255 VPCs it’s maybe time to do things differently
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
well there is data centers using up a ton of the space too
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
all good though.. everyone’s got different use cases..
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
yep
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@nukepuppy we can create another subnets
module specifically for that use-case. want to try together?
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
@Andriy Knysh (Cloud Posse) for sure ! in a few days.. i still gotta get something finished up here.. gonna roll my manual made one for now and wrap that up
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
then id love to re-visit as i feel everytime someone needs to make a vpc
here.. they basically re-invent the wheel
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
last cents @nukepuppy A /21 for a VPC allows 6 /24’s public+private subnets in 3 az’s which is also quite economical, and does allow for enough growth within a VPC. And 8K of VPC’s
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
i cut up a /20 into 7 /23s and 2 /24s for smaller things
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
the /23s usually used for rebuilding kops/eks clusters to test out
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
and the small /24s for things like permanent smaller infra / smaller management vpcs etc
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Sounds like you have a huge platform, how much is terraformed ?
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
depends on diff teams and use cases
data:image/s3,"s3://crabby-images/53d69/53d694d77c0b202729ae92b33eebfcba4d3110f3" alt="nukepuppy avatar"
most is hybrid stuff.. some are heavily orchestrated etc… so it isnt all one stop shop for things
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Beanstalk PR for logging abilities: https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/pull/59
Feature Support log settings. Solution Added support for awshostmanager, awscloudwatch:logs, and awscloudwatchhealth options https://do…