#terraform (2019-08)
Discussions related to Terraform or Terraform Modules
Archive: https://archive.sweetops.com/terraform/
2019-08-01
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
any workaround for
The "count" value depends on resource attributes that cannot be determined
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
I want to use output of MSK bootstrap servers to create R53 CNAME entries
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
don’t reference an output/attribute in count? can only reference vars and locals (and the locals must be fully deterministic in advance, i.e. cannot themselves rely on outputs/attributes)
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
@loren so is it possible to get output from e.g. resource “aws_msk_cluster” and use as count in another resource e.g. “aws_route53_record”
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
not as the count, no, not as far as i know, you’ll always get count cannot be determined errors
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you can use the output in an attribute on another resource, but not in count
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
and you can set the count some other way where the length is fully deterministic from a var or local without relying on an attr of a resource/data source
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
say you pass in a var that determines the number of nodes in your cluster… you can use that var to count aws_route53_record
, and then reference the attrs of aws_msk_cluster
in aws_route53_record
attrs
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
ye I saw workaround with bash echo
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
# Verify that the count matches the list
resource "null_resource" "verify_list_count" {
provisioner "local-exec" {
command = <<SH
if [ ${var.topic_arns_count} -ne ${length(var.topic_arns)} ]; then
echo "var.topic_arns_count must match the actual length of var.topic_arns";
exit 1;
fi
SH
}
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
smth like this
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
here’s the issue with all the fun details, https://github.com/hashicorp/terraform/issues/12570
I was using terraform modules for IAM user creation, add multiple inline policies and multiple policy_arn's to the user after creation. But now I got an issue where I create an IAM_POLICY and g…
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
situation is somewhat improved in tf 0.12, so may run into the error less frequently, but it’s still a problem
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
thnx for answer
data:image/s3,"s3://crabby-images/039ba/039baa410ee95952c1abce9b6daf4cb43d62f76f" alt="Adrian avatar"
2019-08-02
2019-08-03
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
hello @here anyone knows and can recommend good libvirt provider other then this one here > https://github.com/dmacvicar/terraform-provider-libvirt
Terraform provider to provision infrastructure with Linux’s KVM using libvirt - dmacvicar/terraform-provider-libvirt
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
I’m using this with good results. What are you wanting to do?
Terraform provider to provision infrastructure with Linux’s KVM using libvirt - dmacvicar/terraform-provider-libvirt
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
hey @kskewes i have an issue with referencing local image on the server where libvirtd is running
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
# We fetch the latest ubuntu release image from their mirrors
resource "libvirt_volume" "ubuntu-qcow2" {
name = "ubuntu-qcow2"
pool = libvirt_pool.default.name
# path = "/home/ivano/ubuntu-qcow2"
source = "<http://cloud-images.ubuntu.com/releases/xenial/release/ubuntu-16.04-server-cloudimg-amd64-disk1.img>"
format = "qcow2"
}
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
this is what i mean, if you look at the example from terraform-provider-libvirt/examples/v0.12/ubuntu
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
if i try ‘path’ its always local to the server where terraform is started and spinning up webserver on the remote end so i can use source
rather then path is also not ideal, any other ideas?
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Took a little bit to work out cloud init gotchas. https://gitlab.com/kskewes/k8s-with-gitlab/tree/master/terraform/env-dev/libvirt-k8s
Create and maintain a multi-arch Kubernetes cluster utilizing Gitlab CI/CD tools where possible.
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
sweet , thats elegant, thx
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Sorry your other messages didn’t show before I replied but looks like mine will work for you huh :) I haven’t looked at repo on a few months and should look at what can do better with 0.12. any suggestions appreciated, otherwise enjoy!
data:image/s3,"s3://crabby-images/e4e7f/e4e7f366ba1b70765d1db57e9538042da816ef80" alt="ioyu avatar"
thanks @kskewes will check it out. think i found already few issues e.g ‚count‘ as var name cant be used as it conflicts with the modul and there is also few glitches as to how it works in 0.12 , lastly you still pull the source via http…
data:image/s3,"s3://crabby-images/2495f/2495fe62d3d2920120f045143fcc0623b2457a90" alt="kskewes avatar"
Thanks! Will change count. Plan was to turn it into a module anyway. Re source, I use a local file on the kvm server, per example tfvars.
2019-08-04
2019-08-05
data:image/s3,"s3://crabby-images/cd7fd/cd7fdc5c427de680168c4a0e40782529228b648c" alt="sirhopcount avatar"
Does anybody know how to reference an instance created via a google_compute_instance_group_manager
? I’m creating a route via google_compute_route
and I need to have the name of the instance created via the group so I can set next_hop_instance
.
data:image/s3,"s3://crabby-images/8d47e/8d47e333a63b342f2385e9ea8660bdfa54053df5" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Aug 14, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/de7fb/de7fb9146e44c772c992ecc234a51d54df387fb9" alt="Andy avatar"
Will it be recorded and shared post the event, as well?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
we’ve just published our first EMR module (by @Andriy Knysh (Cloud Posse)) https://registry.terraform.io/modules/cloudposse/emr-cluster/aws/0.1.0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an Elastic MapReduce (EMR) cluster on AWS - cloudposse/terraform-aws-emr-cluster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
We’ve been inconsistent about recording them
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
if we do, they’ll be posted to #office-hours
data:image/s3,"s3://crabby-images/de7fb/de7fb9146e44c772c992ecc234a51d54df387fb9" alt="Andy avatar"
NP. Thanks!
data:image/s3,"s3://crabby-images/de7fb/de7fb9146e44c772c992ecc234a51d54df387fb9" alt="Andy avatar"
I am facing an issue with provisioning multiple Windows EC2 instances using Terraform.
This is an overview of my TF template (Oversimplified with syntax ignored):
Template Overview
Resource EC2 {
count = variable
connection
type = "winrm"
host = "${self.private_ip}"
user = "${var.username}"
password = "${var.admin_password}"
timeout = "${var.timeout_tf}"
provisioner remote-exec inline
1. powershell.exe rename-computer -Machine is rebooted once this is run.
provisioner remote-exec inline
2. powershell copy platform code from s3 bucket
3. powershell.exe run DomainAdd.ps1 - Machine is rebooted once this is run.
provisioner remote-exec inline
4. powershell.exe run PreDeploy.ps1 (DSC script)
}
- If I set the count of the instance to 1. All the above #1, #2, #3 and #4 provisioning steps work fine.
Issue:
If I set the count of the instance to anything other than 1 (e.g. 2), Terraform successfully runs #1, #2 and #3 on both the instances and runs #4 on ONLY ONE of the instances.
Observations:
- After running #3 on both the instances, the remote-exec is able to eastablish the connection with both the instances successfully however runs #4 on only one of the instances.
- Even after running #4 on one instance, it keeps on showing the following output unless I force TF to stop.
aws_instance.ec2instance[1]: Still creating... [7m0s elapsed] aws_instance.ec2instance[0]: Still creating... [7m0s elapsed] aws_instance.ec2instance[1]: Still creating... [7m10s elapsed] aws_instance.ec2instance[0]: Still creating... [7m10s elapsed] aws_instance.ec2instance[0]: Still creating... [7m20s elapsed] aws_instance.ec2instance[1]: Still creating... [7m20s elapsed] aws_instance.ec2instance[1]: Still creating... [7m30s elapsed] aws_instance.ec2instance[0]: Still creating... [7m30s elapsed] aws_instance.ec2instance[0]: Still creating... [7m40s elapsed] aws_instance.ec2instance[1]: Still creating... [7m40s elapsed] aws_instance.ec2instance[1]: Still creating... [7m50s elapsed]
Why is Terraform behaving inconsistently when the instance count is set to anything other than 1? Is there something I might be missing? Any suggestions/pointers will be greatly appreciated! TF_LOG are not showing anything useful.
2019-08-06
data:image/s3,"s3://crabby-images/5042b/5042b8de35505a9d6cce511c37b04b876fcc09a0" alt="Hetal S avatar"
Need help in accessing values as a list element inside map values in terraform
data:image/s3,"s3://crabby-images/5042b/5042b8de35505a9d6cce511c37b04b876fcc09a0" alt="Hetal S avatar"
variable "controller_name" {
type = "list"
default = [{
z1 = ["EKS-controller1"]
z2 = []
z3 = ["EKS-controller1","EKS-controller2"]
z4 = []
}]
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can use element() or […] to access the list items
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for maps, The syntax is var.MAP[“KEY”]. For example, ${var.amis[“us-east-1”]} would get the value of the us-east-1 key within the amis map variable.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for lists the syntax is “${var.LIST}“. For example, “${var.subnets}” would get the value of the subnets list, as a list. You can also return list elements by index: ${var.subnets[idx]}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Embedded within strings in Terraform, whether you’re using the Terraform syntax or JSON syntax, you can interpolate other values into strings. These interpolations are wrapped in ${}
, such as ${var.foo}
.
data:image/s3,"s3://crabby-images/5042b/5042b8de35505a9d6cce511c37b04b876fcc09a0" alt="Hetal S avatar"
this is how the variable looks like
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@mmarseglia we converted the module to TF 0.12 https://github.com/cloudposse/terraform-aws-ecr/releases/tag/0.7.0
Terraform Module to manage Docker Container Registries on AWS ECR - cloudposse/terraform-aws-ecr
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and this example are automatically tested on CI/CD https://github.com/cloudposse/terraform-aws-ecr/tree/master/examples/complete
Terraform Module to manage Docker Container Registries on AWS ECR - cloudposse/terraform-aws-ecr
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
can you try with TF 0.12?
data:image/s3,"s3://crabby-images/cb2d6/cb2d66dbb64e02b756efce7bac43166185fba314" alt="mmarseglia avatar"
i’m not sure all the modules I’m using have been converted. they weren’t, last I checked.
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"
Terraform Module to manage Docker Container Registries on AWS ECR - cloudposse/terraform-aws-ecr
data:image/s3,"s3://crabby-images/cb2d6/cb2d66dbb64e02b756efce7bac43166185fba314" alt="mmarseglia avatar"
i built a manifest using elasticbeanstalk app w/ a multidocker container.
data:image/s3,"s3://crabby-images/cb2d6/cb2d66dbb64e02b756efce7bac43166185fba314" alt="mmarseglia avatar"
i am using 7 different modules. i think the elasticbeakstalk ones haven’t been converted yet?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
no, benstalk has not been converted yet
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i mean that we converted https://github.com/cloudposse/terraform-aws-ecr/releases/tag/0.7.0 to TF 0.12 a few weeks ago and it did not throw any policy errors
data:image/s3,"s3://crabby-images/cb2d6/cb2d66dbb64e02b756efce7bac43166185fba314" alt="mmarseglia avatar"
yes, i would like to use the new one. you have done great work converting them in a short time.
data:image/s3,"s3://crabby-images/cb2d6/cb2d66dbb64e02b756efce7bac43166185fba314" alt="mmarseglia avatar"
i’ll figure out a way around this in the short term and look to upgrade that module to 0.7.0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@mmarseglia try to delete the statement = []
from https://github.com/cloudposse/terraform-aws-ecr/blob/0.6.1/main.tf#L124
Terraform Module to manage Docker Container Registries on AWS ECR - cloudposse/terraform-aws-ecr
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we don’t have it in TF 0.12 version https://github.com/cloudposse/terraform-aws-ecr/blob/master/main.tf#L120
Terraform Module to manage Docker Container Registries on AWS ECR - cloudposse/terraform-aws-ecr
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(and we tested only 0.12 version recently)
data:image/s3,"s3://crabby-images/46ad0/46ad000ac65c545f2179c3f9059d58efe0ea0ac7" alt="sweetops avatar"
If someone from Cloudposse gets a chance to review a PR: https://github.com/cloudposse/terraform-aws-datadog-integration/pull/11
Some minor updates to allow the module to work with Terraform 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@sweetops thanks for the PR, looks good, please see the comments https://github.com/cloudposse/terraform-aws-datadog-integration/pull/11#pullrequestreview-272305121
Some minor updates to allow the module to work with Terraform 0.12
2019-08-07
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Guys, I am looking how can I tag resources dynamically, and without repeating same block of code with one change.
# Resource 1
tags = merge(
var.tags,
map(
"Name", format("dev-bastion-0%s.${var.domain}",count.index+1),
"type", "bastion"
)
)
# Resource 2
tags = merge(
var.tags,
map(
"Name", format("dev-app-0%s.${var.domain}",count.index+1),
"type", "app"
)
)
any suggestions are welcome, thanks. Okay I see now that I could just abstract that with module
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
i am not sure, but, i guess you could do follow this way: example:
data "null_data_source" "tags" {
count = "${length(keys(var.tags))}"
inputs = {
key = "${select(keys(var.tags), count.index)}"
value = "${select(values(var.tags), count.index)}"
propagate_at_launch = true
}
}
resource "aws_autoscaling_group" "asg" {
...
tags = "${data.null_data_source.tags.*.outputs}"
}
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
terraform 0.12 you can do it with foreach operator
dynamic "tag" {
foreach = "${local.common_tags}"
content {
key = "${dynamic.foreach.name}"
value = "${dynamic.foreach.value}"
}
}
data:image/s3,"s3://crabby-images/02a47/02a47a301522555fd984b36597a8f89d132a7f3a" alt="Ruan Arcega avatar"
i hope it’s helpfull for you
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#office-hours hours starting in 15m https://zoom.us/meeting/register/dd2072a53834b30a7c24e00bf0acd2b8
2019-08-08
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 wonder what the backstory is here…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
a) why did they launch with HCL support
data:image/s3,"s3://crabby-images/58038/58038b05d79ca7db6a1153a61ed5d38847b32b23" alt="Blaise Pabon avatar"
They had not yet been purchased by MSFT
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
b) why did they drop HCL support
data:image/s3,"s3://crabby-images/58038/58038b05d79ca7db6a1153a61ed5d38847b32b23" alt="Blaise Pabon avatar"
MSFT didn’t want to dilute the brand with a bush league API…
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
haha, possibly!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
strange that they even started with HCL support
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
maybe the devs working on that feature were also supporting the terraform github provider, and thought, wouldn’t it be neat if…?
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
Hi all, this is probably a very dumb and novice questions, but I’m having a hard time understanding what I’m doing wrong here. As far as I can tell, when I try to attach a policy document using a role from the CP role repository, the base module is expecting a string?
data "aws_iam_policy_document" "s3_full_access" {
statement {
sid = "FullAccess"
effect = "Allow"
resources = [
"arn:aws:s3:::${module.static-app.s3_bucket}",
"arn:aws:s3:::${module.static-app.s3_bucket}/*"
]
actions = [
"s3:PutObject",
"s3:PutObjectAcl",
"s3:GetObject",
"s3:DeleteObject",
"s3:ListBucket",
"s3:ListBucketVersions",
"s3:ListBucketMultipartUploads",
"s3:GetBucketLocation",
"s3:AbortMultipartUpload",
]
}
}
module "s3-write-role" {
source = "git::<https://github.com/cloudposse/terraform-aws-iam-role.git?ref=0.4.0>"
enabled = "true"
namespace = "${var.namespace}"
stage = "${var.stage}"
name = "${var.name}"
policy_description = "Allow S3 FullAccess"
role_description = "IAM role with permissions to perform actions on S3 resources"
policy_documents = ["${data.aws_iam_policy_document.s3_full_access.json}"]
}
I’m wondering if I’m missing something ovbious here, or not understanding how to use this module?
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
Follow up error
Error: Incorrect attribute value type
on .terraform/modules/s3-write-role.aggregated_assume_policy/main.tf line 23, in data "aws_iam_policy_document" "zero":
23: override_json = "${element(local.policies, 0)}"
Inappropriate value for attribute "override_json": string required.
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
You are missing something there
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Why error says aggregated_assume_policy ?
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Oh, your source is a git tag
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
I’m sorry, I’m not understanding what the source of confusion is? Could you possibly rephrase?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Rich Allen can you look at the example https://github.com/cloudposse/terraform-aws-iam-role/blob/master/example/main.tf
A Terraform module that creates IAM role with provided JSON IAM polices documents. - cloudposse/terraform-aws-iam-role
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(I personally did not test the latest changes to the module, so can’t just say what’s the exact issue is)
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
That is the example I’m working from. I’ve looked through it several times. And can’t see a difference. From what I can tell, my only real difference is I don’t have an outputs.tf
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
is is required I have that file, so that the module exposes the outputs to the consumer?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok I see the issue https://github.com/cloudposse/terraform-aws-iam-policy-document-aggregator/blob/master/main.tf#L6
Terraform module to aggregate multiple IAM policy documents into single policy document. - cloudposse/terraform-aws-iam-policy-document-aggregator
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it does not work with one item in the list
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since it checks only for >1
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
well so, I can provide and update, and I’m using 2
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
so the base + full admin, as the example suggests
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
policy_documents = [“${data.aws_iam_policy_document.s3_full_access.json}“]
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
the previous was to simplify, I will post an updated stanza
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
I’m now using 2 as the example suggests
provider "aws" {
region = "${var.region}"
}
module "static-app" {
source = "git::<https://github.com/cloudposse/terraform-aws-cloudfront-s3-cdn.git?ref=0.10.0>"
namespace = "${var.namespace}"
stage = "${var.stage}"
name = "${var.name}"
aliases = "${var.aliases}"
parent_zone_name = "${var.parent_zone_name}"
default_root_object = "${var.default_root_object}"
acm_certificate_arn = "${var.acm_certificate_arn}"
cors_allowed_headers = ["GET", "HEAD"]
cors_allowed_methods = ["GET", "HEAD"]
cors_allowed_origins = ["*"]
}
data "aws_iam_policy_document" "s3_full_access" {
statement {
sid = "FullAccess"
effect = "Allow"
resources = ["arn:aws:s3:::${module.static-app.s3_bucket}/*"]
actions = [
"s3:PutObject",
"s3:PutObjectAcl",
"s3:GetObject",
"s3:DeleteObject",
"s3:ListBucket",
"s3:ListBucketMultipartUploads",
"s3:GetBucketLocation",
"s3:AbortMultipartUpload",
]
}
}
data "aws_iam_policy_document" "base" {
statement {
sid = "BaseS3Access"
actions = [
"s3:ListBucket",
"s3:ListBucketVersions",
]
resources = ["*"]
effect = "Allow"
}
}
module "s3-write-role" {
source = "git::<https://github.com/cloudposse/terraform-aws-iam-role.git?ref=0.4.0>"
enabled = "true"
namespace = "${var.namespace}"
stage = "${var.stage}"
name = "${var.name}"
policy_description = "Allow S3 FullAccess"
role_description = "IAM role with permissions to perform actions on S3 resources"
policy_documents = [
"${data.aws_iam_policy_document.base.json}",
"${data.aws_iam_policy_document.s3_full_access.json}"
]
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
working for you?
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
no this is the result of that update
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
17:04 $ terraform plan
Error: Incorrect attribute value type
on .terraform/modules/s3-write-role.aggregated_assume_policy/main.tf line 23, in data "aws_iam_policy_document" "zero":
23: override_json = "${element(local.policies, 0)}"
Inappropriate value for attribute "override_json": string required.
Error: Incorrect attribute value type
on .terraform/modules/s3-write-role.aggregated_policy/main.tf line 23, in data "aws_iam_policy_document" "zero":
23: override_json = "${element(local.policies, 0)}"
Inappropriate value for attribute "override_json": string required.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what TF version are you using?
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
17:04 $ terraform -v Terraform v0.12.2
- provider.aws v2.22.0
- provider.local v1.3.0
- provider.null v2.1.2
- provider.template v2.1.2
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Ok, I’m seeing something nasty
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
I hope it’s not something that dumb like I forgot brew update
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Terraform module to aggregate multiple IAM policy documents into single policy document. - cloudposse/terraform-aws-iam-policy-document-aggregator
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this module has not been updated to TF 0.12 yet https://github.com/cloudposse/terraform-aws-iam-role
A Terraform module that creates IAM role with provided JSON IAM polices documents. - cloudposse/terraform-aws-iam-role
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s why the errors
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
In some point you are using this source: https://github.com/cloudposse/terraform-aws-iam-policy-document-aggregator.git?ref=tags/0.1.2
Terraform module to aggregate multiple IAM policy documents into single policy document. - cloudposse/terraform-aws-iam-policy-document-aggregator
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Which is this https://github.com/cloudposse/terraform-aws-iam-role/blob/05d1734bc40a73d6f21387b58c1f3204dbbe09aa/main.tf
A Terraform module that creates IAM role with provided JSON IAM polices documents. - cloudposse/terraform-aws-iam-role
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Main file
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
so I’m a noobie here, @Andriy Knysh (Cloud Posse) where is that documented? I’m not seeing it but that could be true.
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
At line 23, you will see the error
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
both modules were not converted to TF 0.12 yet
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s why TF 0.12 throws the errors
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we’ll get to it soon
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
@Joan Hermida I’m not sure I understand the context there
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
Downgrade to the latest 0.11 version
data:image/s3,"s3://crabby-images/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
@Andriy Knysh (Cloud Posse) could you just point out where I can see that? To avoid version mismatches in the future?
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so for CloudPosse modules, the ones that were converted to TF 0.12 have hcl2
tag in the repo, e.g. https://github.com/cloudposse/terraform-aws-rds
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"
and you can tell TF 0.11 from TF 0.12 by the syntax
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
TF 0.12 does not use any string interpolations 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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and uses real first-class types like bool
, number
, list(string)
, map(string)
instead if strings like “string” and “list” https://github.com/cloudposse/terraform-aws-rds/blob/master/variables.tf#L19
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/728b9/728b9e4658087ebe0211af52b7190b3030120b8e" alt="Rich Allen avatar"
ty, that’s very helpful, I’m getting a few new errors related to the downgrade but I’ll fix these up. Much appreciate the help.
data:image/s3,"s3://crabby-images/48b02/48b02ca67d94f843d1c6179d7e264e2509f59f46" alt="Joan Hermida avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Hello, I’m using : “git://github.com/cloudposse/terraform-aws-alb-target-group-cloudwatch-sns-alarms.git?ref=tags/0.6.1>” and I notice when using the newer alb module that target_group_name = “${module.alb.target_group_name}” and target_group_arn_suffix = “${module.alb.target_group_arn_suffix}” are not valid outputs anymore so it can’t be use with this cloudwatch-sns module, are you guys deprecating the use of the cloudwatch-sns-alarms or recommend something else ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and now I think I found a bug , I’m getting this :
Error: Error running plan: 1 error occurred:
* module.alb_ingress.local.target_group_arn: local.target_group_arn: Resource 'aws_lb_target_group.default' not found for variable 'aws_lb_target_group.default.arn'
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
locals {
target_group_enabled = "${var.target_group_arn == "" ? "true" : "false"}"
target_group_arn = "${local.target_group_enabled == "true" ? aws_lb_target_group.default.arn : var.target_group_arn}"
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
If I pass the ARN or the module output still fails
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
unless I’m doing something really wrong
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I made a copy of the module , removed the data resource and it does work, so I’m guessing this lies : https://github.com/cloudposse/terraform-aws-alb-ingress/blob/0.7.0/main.tf#L6
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
don’t really need to be there ? why making a lookup of something I’m already passing and creating that data resource that is not used in that tf ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I guess is to check that the target group exists before continuing but in my case I used -target module.alb to make sure I had everything before continuing but somehow still fails
2019-08-09
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
Hi everyone - new to the channel but was hoping to find a solution to a problem I am running into dealing with output variables from modules
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
I use the aws vpc terraform module, and there is a specific output that that gets created as a list, specifically the database subnet output. I am trying to reference this output as an input variable for an rds module
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
does anyone know how to properly reference an output list generated by a module, as an input variable for another module?
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
any guidance or direction would be sincerely appreciated
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
outputs types are the same regardless whether it’s a list or a string
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for a working example see https://github.com/cloudposse/terraform-aws-emr-cluster/blob/master/examples/complete/main.tf
Terraform module to provision an Elastic MapReduce (EMR) cluster on AWS - cloudposse/terraform-aws-emr-cluster
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and another example where the list output from the subnet module goes into the elasticsearch module https://github.com/cloudposse/terraform-aws-elasticsearch/blob/master/examples/complete/main.tf#L33
Terraform module to provision an Elasticsearch cluster with built-in integrations with Kibana and Logstash. - cloudposse/terraform-aws-elasticsearch
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
same for RDS https://github.com/cloudposse/terraform-aws-rds/blob/master/examples/complete/main.tf#L45
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"
and RDS Aurora https://github.com/cloudposse/terraform-aws-rds-cluster/blob/master/examples/complete/main.tf#L40
Terraform module to provision an RDS Aurora cluster for MySQL or Postgres - cloudposse/terraform-aws-rds-cluster
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
bingo!
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
thank you @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
any ideas on this ?
and now I think I found a bug , I’m getting this :
Error: Error running plan: 1 error occurred:
* module.alb_ingress.local.target_group_arn: local.target_group_arn: Resource 'aws_lb_target_group.default' not found for variable 'aws_lb_target_group.default.arn'
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I know the posts from yesterday usually get buried….
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what module are you using? can you share the code
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and now I think I found a bug , I’m getting this :
Error: Error running plan: 1 error occurred:
* module.alb_ingress.local.target_group_arn: local.target_group_arn: Resource 'aws_lb_target_group.default' not found for variable 'aws_lb_target_group.default.arn'
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
mmm that did not work, my complete post is just a higher
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@jose.amengual here is how we use aws-alb-ingress
https://github.com/cloudposse/terraform-aws-ecs-web-app/blob/master/main.tf#L34
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"
aws-ecs-web-app
is used here https://github.com/cloudposse/terraform-aws-ecs-atlantis/blob/master/main.tf#L78
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which itself is used here (working example) https://github.com/cloudposse/terraform-root-modules/blob/master/aws/ecs/atlantis.tf#L173
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is exactly where I got the example :
module "alb_ingress" {
#source = "git::<https://github.com/cloudposse/terraform-aws-alb-ingress.git?ref=tags/0.7.0>"
source = "../terraform-aws-alb-ingress"
name = "${var.name}"
namespace = "${var.namespace}"
stage = "${var.stage}"
attributes = "${var.attributes}"
vpc_id = "${var.vpc_id}"
port = "${var.container_port}"
health_check_path = "${var.health_check_path}"
target_group_arn = "${module.alb.default_target_group_arn}"
# Without authentication, both HTTP and HTTPS endpoints are supported
unauthenticated_listener_arns = ["${module.alb.listener_arns}"]
unauthenticated_listener_arns_count = 1
# All paths are unauthenticated
unauthenticated_paths = ["/*"]
unauthenticated_priority = "100"
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
locals {
target_group_enabled = "${var.target_group_arn == "" ? "true" : "false"}"
target_group_arn = "${local.target_group_enabled == "true" ? aws_lb_target_group.default.arn : var.target_group_arn}"
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
when this evaluation happens , for some reason this :
data "aws_lb_target_group" "default" {
arn = "${local.target_group_arn}"
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
can’t find the ALB
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and I’m 100% sure the value is correct
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I mean the arn
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but that data resource is the one that fails but is not anywhere else int he code
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Did you provision the ALB?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
module "alb" {
source = "git::<https://github.com/cloudposse/terraform-aws-alb.git?ref=tags/0.5.0>"
name = "${var.name}"
namespace = "${var.namespace}"
stage = "${var.stage}"
attributes = ["${compact(concat(var.attributes, list("alb")))}"]
vpc_id = "${var.vpc_id}"
ip_address_type = "ipv4"
subnet_ids = "${var.subnet_ids}"
security_group_ids = [""]
access_logs_region = "${var.region}"
http_enabled = "true"
https_enabled = "false"
http_ingress_cidr_blocks = ["0.0.0.0/0"]
https_ingress_cidr_blocks = ["0.0.0.0/0"]
certificate_arn = "${var.certificate_arn}"
health_check_interval = "60"
health_check_path = "${var.health_check_path}"
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is right before
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes first
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Look at the root modules ECS folder
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Did you try to run terraform apply second time?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Sometimes there race conditions
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I used target module.alb
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
then I run the rest
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Where some resources are not created yet
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I understand
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I run target module.alb twice
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
then run the rest
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Try running the rest twice
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I did too
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m destroying everything again right now
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the thing is : even if I set
target_group_arn = "${module.alb.default_target_group_arn}"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
to the target group arn itself
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it does not work
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I ran this project https://github.com/cloudposse/terraform-root-modules/tree/master/aws/ecs about 35 times, but never saw it could not find the target group
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I saw in many cases that the ALB was not ready yet (it’s slow), so it could not attach the target group
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ALB created :
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
module.alb.aws_lb.default: Creation complete after 2m16s (ID: arn:aws:elasticloadbalancing:us-east-1:...ging-demo-droneio-alb/0ff8d366761cb319)
module.alb.aws_lb_listener.http: Creating...
arn: "" => "<computed>"
default_action.#: "" => "1"
default_action.0.order: "" => "<computed>"
default_action.0.target_group_arn: "" => "arn:aws:elasticloadbalancing:us-east-1:234234234234:targetgroup/staging-demo-droneio-alb-default/a11e7a7298308db8"
default_action.0.type: "" => "forward"
load_balancer_arn: "" => "arn:aws:elasticloadbalancing:us-east-1:234234234234:loadbalancer/app/staging-demo-droneio-alb/0ff8d366761cb319"
port: "" => "80"
protocol: "" => "HTTP"
ssl_policy: "" => "<computed>"
module.alb.aws_lb_listener.http: Creation complete after 1s (ID: arn:aws:elasticloadbalancing:us-east-1:...-alb/0ff8d366761cb319/fbc88868db406827)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
target group is there
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and same error :
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
aws-vault exec hds-admin -- terraform apply -target module.alb_ingress 34s Fri 9 Aug 11:20:21 2019
null_resource.default: Refreshing state... (ID: 938128705396491941)
aws_lb_target_group.default: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...o-droneio-alb-default/c5d32c308b13dee7)
aws_security_group.default: Refreshing state... (ID: sg-0dca458073974ca29)
data.aws_elb_service_account.default: Refreshing state...
data.aws_iam_policy_document.default: Refreshing state...
aws_s3_bucket.default: Refreshing state... (ID: staging-demo-droneio-alb-alb-access-logs)
aws_lb.default: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...ging-demo-droneio-alb/61f67535cafe2201)
aws_lb_listener.http: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...-alb/61f67535cafe2201/8e7ac22fe675d697)
Error: Error running plan: 1 error occurred:
* module.alb_ingress.local.target_group_arn: local.target_group_arn: Resource 'aws_lb_target_group.default' not found for variable 'aws_lb_target_group.default.arn'
`
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
that is after running 3 times the alb creation
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
after running the whole thing second time, the ALB is already ready, and it finishes provisioning the rest
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
yes, ALBs are really slow
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m running this thing again just to make sure I did’t do anything stupid
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
just tried from zero and run the alb target 3 times, waited few minutes and tun module.alb_ingress and I get the same error
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
null_resource.default: Refreshing state... (ID: 938128705396491941)
aws_security_group.default: Refreshing state... (ID: sg-0dca458073974ca29)
aws_lb_target_group.default: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...o-droneio-alb-default/c5d32c308b13dee7)
data.aws_elb_service_account.default: Refreshing state...
data.aws_iam_policy_document.default: Refreshing state...
aws_s3_bucket.default: Refreshing state... (ID: staging-demo-droneio-alb-alb-access-logs)
aws_lb.default: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...ging-demo-droneio-alb/61f67535cafe2201)
aws_lb_listener.http: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...-alb/61f67535cafe2201/8e7ac22fe675d697)
Error: Error running plan: 1 error occurred:
* module.alb_ingress.local.target_group_arn: local.target_group_arn: Resource 'aws_lb_target_group.default' not found for variable 'aws_lb_target_group.default.arn'
`
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so I can consistently reproduce the issue
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I can run this :
terraform apply -target data.aws_lb_target_group.default
aws_lb_target_group.default: Refreshing state... (ID: arn:aws:elasticloadbalancing:us-east-1:...o-droneio-alb-default/c5d32c308b13dee7)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
with same code is failing in the module and it does not fail outside of it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so, something is happening here :
locals {
target_group_enabled = "${var.target_group_arn == "" ? "true" : "false"}"
target_group_arn = "${local.target_group_enabled == "true" ? aws_lb_target_group.default.arn : var.target_group_arn}"
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what TF version are you using?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Terraform v0.11.14
+ provider.aws v2.23.0
+ provider.local v1.3.0
+ provider.null v2.1.2
+ provider.random v2.2.0
+ provider.template v2.1.2
+ provider.tls v2.0.1
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i think you are running into some race conditions
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
where this https://github.com/cloudposse/terraform-aws-alb-ingress/blob/master/main.tf#L21 has not been created yet
Terraform module to provision an HTTP style ingress rule based on hostname and path for an ALB using target groups - cloudposse/terraform-aws-alb-ingress
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but this https://github.com/cloudposse/terraform-aws-alb-ingress/blob/master/main.tf#L6 is already being used in the outputs
Terraform module to provision an HTTP style ingress rule based on hostname and path for an ALB using target groups - cloudposse/terraform-aws-alb-ingress
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but
resource "aws_lb_target_group" "default" {
count = "${local.target_group_enabled == "true" ? 1 : 0}"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
will only be created if target_group_arn is = “”
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
base on the locals evaluation
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so it should not even be trying to create this resource ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so yes, you either provide one, or the module will create it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
in my case I’m providing one
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so you think somehow the evaluation is failing ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
even if I pass the raw arn value still fails
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
ok yes, there is a bug in that flow. we always created target group in the module (did not test when you provide one)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the bug is…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this https://github.com/cloudposse/terraform-aws-alb-ingress/blob/master/main.tf#L21 uses count
so any output from it is a list
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an HTTP style ingress rule based on hostname and path for an ALB using target groups - cloudposse/terraform-aws-alb-ingress
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
target_group_arn = "${local.target_group_enabled == "true" ? join("", aws_lb_target_group.default.*.arn) : var.target_group_arn}"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you need to exampling me this a bit more
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
are you saying that the data resource : aws_lb_target_group.default output is a list ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
any output from it is a list
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since it has count
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
even with count=1, it’s a list with one item
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ahhhh yes….exactly
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but I thought L3 was referencing :
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data "aws_lb_target_group" "default" {
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and not
resource "aws_lb_target_group" "default" {
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this is where I’m confused
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is there a order of preference ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
your error was referencing resource “aws_lb_target_group” “default”
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which itself is used in the locals
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
which itself is used in data “aws_lb_target_group” “default”
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but local.target_group_enabled is false since I’m passing the target group arn
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so it should have taken the value of var.target_group_arn
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
TF always evaluates both sides of ternary operator
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
maybe this is some basic terraform I’m missing
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an HTTP style ingress rule based on hostname and path for an ALB using target groups - cloudposse/terraform-aws-alb-ingress
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks a lot @jose.amengual
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this is my first PR where I do not understand the fix lol
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
haha
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m reading the docs again that evaluation thing is screwing with my head
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
TF parses both sides of ?
operator in case of true
or false
, does not matter
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I don’t get the reasoning behind evaluating when the if-statement is already false
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
since the target group resource is disabled by providing your own target group, it does not have any outputs
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when TF tries to get an output on non existing resource, it fails
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
join(“”, xxx.*.yyy) works because even with non existing resource, it returns an empty string
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
I don’t get the reasoning behind evaluating when the if-statement is already false
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
blame TF
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s how they did it 20 years ago in the mainstream languages
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ok so since the resource has count the output instead of being a string is a list and since we are evaluating strings it fails
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
something like that ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
when you start a new parser/compiler, you have to go through all of that again, and it’s not easy
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I always blame TF lol
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
ohhh wait the join is basically acting like a try catch so even is the output is empty it return a sane value
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it returns an empty string even if the list is empty or NULL
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
please tell me this is better in 0.12
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
please…..
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you are lucky
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
As part of the lead up to the release of Terraform 0.12, we are publishing a series of feature preview blog posts. The post this week is on the improvements to conditional operator…
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
by the way, everything is working perfectly now
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
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/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
for sure
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
thanks for finding it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
this thing has been killing me, I though I was doing something wrong
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I know I have to run few commands before I create the PR
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
are those documented somewhere ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you mean to rebuild README?
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/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need that if you change any variable or outputs or README.yaml (not in this case where you just fix the code)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but run it anyway
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I see ok
data:image/s3,"s3://crabby-images/1621c/1621c70949e59d65bdd56b6da03bc4bd6a62cdf7" alt="Mike Nock avatar"
Has anyone here used terraform as the CD portion of the CI/CD pipeline? Currently, I’m deploying docker images to ECR with Gitlab, but I’m running into an issue where I need to somehow tell terraform to update it’s workspaces once a new image comes out. Was curious if anyone else had run into this / figured this out
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Mike Nock you mean that terraform is somehow constantly running and waiting for commands? Or it’s a manual process?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if manual, you can use https://www.terraform.io/docs/providers/aws/d/ecr_image.html to retrieve information about images
Provides details about an ECR Image
data:image/s3,"s3://crabby-images/1621c/1621c70949e59d65bdd56b6da03bc4bd6a62cdf7" alt="Mike Nock avatar"
Yea, currently the pipeline is Gitlab > Docker > ECR for CI, and then manually deploying the images by going into TFE and updating the workspace so teraform sees the new image (the CI pipeline retags the image with :production and removes that tag from the old image when deploying to ECR, and terraform is set to only use the image with that tag). I’d like to automate that. So, when the developers push a new feature to master, it build, deposits the image, and then either sends an API call to terraform to update (prefer not doing it this way), or preferably someway of having terraform monitor the tags, and deploy once the tag is removed?
data:image/s3,"s3://crabby-images/1621c/1621c70949e59d65bdd56b6da03bc4bd6a62cdf7" alt="Mike Nock avatar"
Also, for backstory, the reason I prefer not doing the api calls to update, is we are doing self-service terraform where client environments are being created regularly and dynamically, so I wouldn’t have a list of all the workspaces to send individual API calls to, and you can’t send 1 api call to update all workspaces, same as you can’t send 1 api call with a map of variables for the workspace but have to list out each one by one in separate calls.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s interesting (but we at CloudPosse did not use TFE)
data:image/s3,"s3://crabby-images/1621c/1621c70949e59d65bdd56b6da03bc4bd6a62cdf7" alt="Mike Nock avatar"
Understandable, just figured it was worth asking if anyone else had run into it. Thanks!
data:image/s3,"s3://crabby-images/5042b/5042b8de35505a9d6cce511c37b04b876fcc09a0" alt="Hetal S avatar"
1 error occurred:
* module.s3cdn-dev.aws_route53_record.cert_validation: At column 19, line 1: list "local.dvo" does not have any elements so cannot determine type. in:
${lookup(local.dvo[count.index], "resource_record_value")}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I was looking at : https://github.com/cloudposse/terraform-aws-rds-cluster/blob/0.11/master/examples/basic/main.tf#L6 what is all that witchcraft ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m guessing that is only available in providers and should not be used with other terraform code except rds ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
those are attributes on the provider which you can use to disable some checks if you want to run it faster
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
has nothing to do with RDS
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
used in some tests
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but not necessary at all
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
RDS takes so long I was thinking on adding them to my big TF but I was not sure if they could break something
2019-08-10
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Do you have module which covers ACM Certificate for CloudFront if Route 53 HostedZone is not in us-east-1?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s a provider thing https://github.com/cloudposse/terraform-root-modules/blob/master/aws/acm-cloudfront/main.tf#L12
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Thanks @Andriy Knysh (Cloud Posse) Of course, its provider thing, I may miss something, but I don’t see how this reference address my use case
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
If I see well it presume that Hosted Zone is in same Region
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
or i take that back
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
sorry
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
Hosted Zones are global
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Yes hosted zones are global
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
You create a certificate in us-east-1 using different provider
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Then reference the cert ARN when you create a distribution
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
@Andriy Knysh (Cloud Posse) Thank, I did that, but i messed up something else which made me problem
data:image/s3,"s3://crabby-images/a25bb/a25bbe7dc97c91f827da346fc9f35c1c4c6cf230" alt="Milos Backonja avatar"
provisioning atm, everything looks good so far
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
regarding the HCL deprecation on github action
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
is very likely due to the recent news that github action will have built-in CI/CD
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
and given github is owned by microsoft
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
is very likely the backend is azuredevops
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
and until next tuesday, automation for azuredevops pipeline is in yaml
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
@Andriy Knysh (Cloud Posse) after much time, upcoming tuesday is the decided to release the azuredevops terraform provider
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
decided day*
2019-08-11
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
Are there any known bugs with the ec2 module, release 0.11?
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
deployed an ec2 instance using the ec2 module, and had associate_public_ip_address set to true. Changed it to false from true, which then prompted a redeploy, now it fails with the error: value = coalesce( aws_eip.default is empty tuple aws_instance.default is tuple with 1 element Call to function “coalesce” failed: no non-null, non-empty-string arguments.
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
I cant destroy or apply any updates to my entire deployment
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
looks like there is a pull request for this specific issue: https://github.com/cloudposse/terraform-aws-ec2-instance/pull/45
Terraform changed handling of coalesce function to error out when there are no non-null non-empty elements on the list. This results in an error while configuring an instance with no EIP assigned t…
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
does anyone know if there is a temp workaround for this?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@LeoGmad you can fork the branch of the PR and use that one ?
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
I will try, thank you @maarten
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
I was able to successful fork the PR but issue still persists. I would be interested if anyone has been successful with this PR or finding a workaround
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
the only way to resolve is to set all instances “associate_public_ip_address = true”
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
which I guess isnt a big deal as long as they’re deployed behind a NAT or limited ACL
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Leonard Wood ok let me run the example with associate_public_ip_address set to false, and see what can be done.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Leonard Wood see if it works with the new pr
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
I tried with the new PR but no luck. I am deploying 2 ec2 instances, one set to true and one to set false - and thats when the issue occurs. All ec2 instance deployments have to be set to ‘true’ for it to deploy.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Leonard Wood make sure to clean your cache. I’m running ‘examples/complete’ with instance_enabled = false
and that works
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
Interesting - why the instance_enabled = false flag though?
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
I did delete the .terraform directory and re init so that should have cleared the cache
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
thanks again @maarten for looking into this too
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
sure, ah I’ve tried differnent options, including setting instance_enabled
to false, which was the problem with the original PR.
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
but if that flag is still to false, will the instance deploy?
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
“Flag to control the instance creation. Set to false if it is necessary to skip instance creation”
data:image/s3,"s3://crabby-images/7792c/7792c5fe04ed802d31115f02379b9565d6f68592" alt="Leonard Wood avatar"
set* to false
2019-08-12
data:image/s3,"s3://crabby-images/8d47e/8d47e333a63b342f2385e9ea8660bdfa54053df5" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Aug 21, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/73e87/73e874e38f1c9a149e053f7dd07e4ff48e84a8a2" alt="Vitaliy Lobachev avatar"
Hello! I want to share with you resource:for_each and dynamicfor_each construction for terraform 12.6 . Hope this helps you work with large arrays of resources. https://github.com/devops-best-practices/terraform-best-practice/blob/master/s3.tf
Contribute to devops-best-practices/terraform-best-practice development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Hey people, looking for terraform template on vpc peering ( syntax 0.12) any help plz
data:image/s3,"s3://crabby-images/3eada/3eadad973ecc61f937368f630a7ebac675dc81f8" alt="foqal avatar"
@Sharanya’s question was answered by <@Foqal>
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Hola fellas….
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Quick question here… We have a Terraform RDS module (typical base build format) for the build deployments to use to setup RDS instances in our AWS Setups. Now I am tying to enable alerting (SNS topics with Cloudwatch) within the existing RDS module but not sure how to enable the alerting within an existing RDS module. I found out eh cloud posse GitHub repo (https://github.com/cloudposse/terraform-aws-rds-cloudwatch-sns-alarms) will give the ability to create the sns topics (please do correct me if I am wrong here), but what I need is to enable the alerting within the RDS module so that the users will create the required sns topics based on their needs. Anyone worked on this kind of typical setups before? Any input helps me for my cause here
Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic - cloudposse/terraform-aws-rds-cloudwatch-sns-alarms
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
or even anyone been through this kind of requirement before?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can use the alarms from https://github.com/cloudposse/terraform-aws-rds-cloudwatch-sns-alarms/blob/master/alarms.tf (update them and add new ones if needed)
Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic - cloudposse/terraform-aws-rds-cloudwatch-sns-alarms
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
then you can create an SNS topic in diff module (or manually, or however you need it), and subscribe the RDS instance to the topic https://github.com/cloudposse/terraform-aws-rds-cloudwatch-sns-alarms/blob/master/main.tf#L20
Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic - cloudposse/terraform-aws-rds-cloudwatch-sns-alarms
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(the module currently always creates an SNS topic)
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and since we are talking about SNS alarms :
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m using : “git://github.com/cloudposse/terraform-aws-alb-target-group-cloudwatch-sns-alarms.git?ref=tags/0.6.1>” and I notice when using the newer alb module that target_group_name = “${module.alb.target_group_name}” and target_group_arn_suffix = “${module.alb.target_group_arn_suffix}” are not valid outputs anymore so it can’t be use with this cloudwatch-sns module, are you guys deprecating the use of the cloudwatch-sns-alarms or recommend something else ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
@Andriy Knysh (Cloud Posse) I think that maybe this one it has not be updated to reflect changes on the alb module
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@jose.amengual https://github.com/cloudposse/terraform-aws-alb-target-group-cloudwatch-sns-alarms does not have outputs at all for some reason
Terraform module to create CloudWatch Alarms on ALB Target level metrics. - cloudposse/terraform-aws-alb-target-group-cloudwatch-sns-alarms
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what alb
module are you using that uses terraform-aws-alb-target-group-cloudwatch-sns-alarms
?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I took that from ECS web app example
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it uses alb_ingress
, not terraform-aws-alb-target-group-cloudwatch-sns-alarms
at that line
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
this uses alarms, but does not use any outputs from it https://github.com/cloudposse/terraform-aws-ecs-web-app/blob/master/main.tf#L170
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/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
HAHAHAHAH well so you know I’m dyslexic
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
for example
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Thanks again
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
maybe I’m too old for this
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
haha, it happens feel free to ask any questions
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Sure @Andriy Knysh (Cloud Posse)… Let me give it a try and will update here in the group with the progress..
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"
Interesting!
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@Erik Osterman (Cloud Posse) just implemented this.. works really well
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
can you zoom?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I want to see what you did
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
The part I’m still miffed about is that I can’t use it to terraform init -from-module
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Basically, I want to be dry across repositories
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I don’t want to be dry just in a single repository
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I want to define my root modules once
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I want to use them all over the place.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
ya, so ugh, i see now that I look closer.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
` tfworkspacesettings = yamldecode(local.tfsettingsfilecontent)` is the operative line. this is nice. i get what they are doing. we’ll probably use some thing like this.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
but still this really assumes a monorepo infrastructure strategy and depends on workspaces.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
it’s nice though. pretty elegant. very easy to understand.
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
sorry missed these messages… looks like you got it though… yamldecode
from 0.12.x made this a possibility i can zoom tomorrow if you still need it
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Also @Andriy Knysh (Cloud Posse), just a quick fyi.. we dont use the IAM policy in the main.tf for the SNS topics creation as we use the user aces at higher levels in our build deployments. Is there other way to comment that part out of the module?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you don’t use aws_sns_topic
, then you don’t need the policy as well
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
comment out of the module
: you can fork it and comment out aws_sns_topic
and the policy, or you can open a PR and add new var sns_topic_enabled
(set to true by default for backwards compatibility). Then use count = "${var.sns_topic_enabled == "true" ? 1 : 0}" for
aws_sns_topic and
aws_db_event_subscription and
aws_sns_topic_policy`
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
Without using the aws_sns_topic, how can I subscribe the RDS instance to the topic https://github.com/cloudposse/terraform-aws-rds-cloudwatch-sns-alarms/blob/master/main.tf#L20 (from your above statement dude)?
Terraform module that configures important RDS alerts using CloudWatch and sends them to an SNS topic - cloudposse/terraform-aws-rds-cloudwatch-sns-alarms
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need an SNS topic to subscribe the instance to a topic
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
ok ok
data:image/s3,"s3://crabby-images/feb42/feb42d8449f9d841ca448c849a2d0d4549142408" alt="Vikram Yerneni avatar"
let me comment out the section from the module and will try it out
2019-08-13
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hi Everyone, I’m having the issue that when I attach a private EIP to an instance in a private subnet,, that associate_public_ip_address
gets set to true. This with a subnet with public ip mapping to false. Maybe someone else stumpled upon the same issue ?
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
@maarten what module is this?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
“terraform-aws-modules/ec2-instance/aws” but it’s irrelevant, it’s not a module problem
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
No but I just want to have a look
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
and what is the actual problem? You don’t want associate_public_ip_address
: true ?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
# Grafana
module "grafana" {
source = "terraform-aws-modules/ec2-instance/aws"
version = "~> 2.0"
name = "grafana-xlt"
instance_count = 1
ami = var.grafana_ami
instance_type = "m4.xlarge"
key_name = ""
monitoring = true
vpc_security_group_ids = [module.ec2_sg.this_security_group_id]
subnet_id = module.vpc.private_subnets[0]
#private_ip = "10.0.1.200"
associate_public_ip_address = false
user_data = "{\"auth\": [ {\"name\": \"admin\", \"pass\": \"${var.password}\"}]}"
tags = {
Name = "grafana"
Terraform = "true"
Environment = "dev"
}
}
#resource "aws_eip" "grafana" {
# vpc = true
# associate_with_private_ip = "10.0.1.200"
#}
#
#resource "aws_eip_association" "grafana" {
# instance_id = module.grafana.id[0]
# allocation_id = aws_eip.grafana.id
#}
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
OK, makes more sense seeing that. saying that, I haven’t come across this
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Does the instance then get a routable public IP that you don’t want it to have?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
yep
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Can you deny outside world access via SG rule?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
It’s a human error I think. I thought the EIP would be private, but it’s actually a public EIP .. associated with a private address
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
ah i don’t think you can have a private EIP - you’d need ENI for that … assuming I understood correctly what you want (a private static ip?)
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/0704f/0704fa2c4de34bfc92a8ecd50096a4fa8404549a" alt="joshmyers avatar"
Don’t think that actually works does it?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
EIPs are always public
data:image/s3,"s3://crabby-images/241b8/241b8520f51ffc83b21718b4544f644baba89fa8" alt="Hugo Lesta avatar"
Hello there, do you have any fargate terraform module to analyze and implement in a production environment?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Hugo Lesta take a look at https://github.com/cloudposse/terraform-aws-ecs-web-app
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"
it uses Fargate
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
used by https://github.com/cloudposse/terraform-aws-ecs-atlantis (which deploys atlantis
on ECS Fargate)
Terraform module for deploying Atlantis as an ECS Task - cloudposse/terraform-aws-ecs-atlantis
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the complete atlantis
solution is here https://github.com/cloudposse/terraform-root-modules/tree/master/aws/ecs (uses the two modules above and more)
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/241b8/241b8520f51ffc83b21718b4544f644baba89fa8" alt="Hugo Lesta avatar"
@Andriy Knysh (Cloud Posse) thankss
data:image/s3,"s3://crabby-images/7f190/7f1902c6c058b712c6b83e384e2d273727f47d7f" alt="Julio Tain Sueiras avatar"
2019-08-14
data:image/s3,"s3://crabby-images/bbcc4/bbcc45e2b21f51ed39d757a1197d886dabcbfd1c" alt="Szymon avatar"
Hi, is there any possibility to setup azurerm app service
deployment from bitbucket automatically?
scm_type
block doesn’t work, as described in this issue: https://github.com/terraform-providers/terraform-provider-azurerm/issues/3696
Do you see any alternatives?
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/014e4/014e4b7974f221e4284156ba414e42adc0328a62" alt="Chris Montes avatar"
Hey guys, anyone know how to get terraform-aws-elastic-beanstalk-environment to attach security groups directly to the launch config this module creates? Currently, whatever SGs you list under var.security_groups, they all get added as security group rules of a new SG that this module creates, instead of actually associating the SGs themselves directly to the Launch Config… https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L318
data:image/s3,"s3://crabby-images/014e4/014e4b7974f221e4284156ba414e42adc0328a62" alt="Chris Montes avatar"
https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L489 I guess the best way is to fork this module and customize it here?
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"
in all Cloud Posse modules we usually create a new SG and then add existing SGs and CIDRs blocks to it to allow ingress
data:image/s3,"s3://crabby-images/014e4/014e4b7974f221e4284156ba414e42adc0328a62" alt="Chris Montes avatar"
But how would you allow ingress from external IPs, etc? as nested security groups DO NOT work like that….
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we use external SGs and external CIDRs
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not sure if https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment uses both (we used the module more than a year ago)
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/014e4/014e4b7974f221e4284156ba414e42adc0328a62" alt="Chris Montes avatar"
https://github.com/cloudposse/terraform-aws-elastic-beanstalk-environment/blob/master/main.tf#L486 This setting should be refactored to support a list of paramterized strings
Terraform module to provision an AWS Elastic Beanstalk Environment - cloudposse/terraform-aws-elastic-beanstalk-environment
data:image/s3,"s3://crabby-images/2a6c6/2a6c695b8614351039c75f2ee697c4c216e6a766" alt="github140 avatar"
Hi, I have a general Terraform question. Is anybody using it for deployment of and to HyperV? I found a community provider however I’m a little bit hesitant in using it. Which other gitops based tool would be available for HyperV deployments?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@github140 saw @chrism talking about hyperv in #geodesic last month
data:image/s3,"s3://crabby-images/16bc3/16bc395c4353d07f00573cdb8d968eb3b6dd811a" alt="chrism avatar"
Nah it was just that Docker for Windows creates its VM in hyper-v on windows. We use vsphere/aws/azure
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"
Our public weekly #office-hours is starting now! Join https://zoom.us/j/508587304
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
Hi, I’m trying to create a aws_vpc_peering_connection between 2 accounts, cross region using assume-role and specifying a aws provider for the aws_vpc_peering_connection_accepter with corresponding region. This fails because the requester tries to look for the accepter vpc in the same region and fails to find the vpc. I’ve used this code to successfully deploy cross account, but on the same region. Using TF version 0.11.13
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
This is what the module I’m using looks like:
data "aws_vpc" "accepter" {
provider = "aws.accepter"
id = "${var.accepter_vpc_id}"
}
locals {
accepter_account_id = "${element(split(":", data.aws_vpc.accepter.arn), 4)}"
}
resource "aws_vpc_peering_connection" "requester" {
vpc_id = "${var.requester_vpc_id}"
peer_vpc_id = "${data.aws_vpc.accepter.id}"
peer_owner_id = "${local.accepter_account_id}"
tags {
Name = "peer_to_${var.accepter_tag}"
}
}
resource "aws_vpc_peering_connection_accepter" "accepter" {
provider = "aws.accepter"
vpc_peering_connection_id = "${aws_vpc_peering_connection.requester.id}"
auto_accept = true
tags {
Name = "peer_to_${var.requester_tag}"
}
}
#######################
# ROUTE TABLE UPDATES #
#######################
data "aws_vpc" "requester" {
id = "${var.requester_vpc_id}"
}
data "aws_route_tables" "requester" {
vpc_id = "${var.requester_vpc_id}"
}
data "aws_route_tables" "accepter" {
provider = "aws.accepter"
vpc_id = "${data.aws_vpc.accepter.id}"
}
resource "aws_route" "requester" {
count = "${length(data.aws_route_tables.requester.ids)}"
route_table_id = "${data.aws_route_tables.requester.ids[count.index]}"
destination_cidr_block = "${data.aws_vpc.accepter.cidr_block}"
vpc_peering_connection_id = "${aws_vpc_peering_connection.requester.id}"
}
resource "aws_route" "accepter" {
provider = "aws.accepter"
count = "${length(data.aws_route_tables.accepter.ids)}"
route_table_id = "${data.aws_route_tables.accepter.ids[count.index]}"
destination_cidr_block = "${data.aws_vpc.requester.cidr_block}"
vpc_peering_connection_id = "${aws_vpc_peering_connection.requester.id}"
}
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
and this is how I defined the provider:
provider "aws" {
max_retries = "5"
profile = "${var.aws_profile_name}"
region = "${var.accepter_region}"
skip_get_ec2_platforms = true
skip_region_validation = true
alias = "accepter"
assume_role {
role_arn = "${var.accepter_role_arn}"
}
}
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
So this works perfectly if both VPC’s are on the same region, but when one of the VPC’s is on another region the requester peering connection regions (both accepter and requeter) shows up in AWS console as the same as the requester, thus failing to find the VPC.
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
Is there a way to specify the accepter’s region?
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Hi @Alejandro Rivera I haven’t done this specifically with peering connections, but I have done this with a TGW
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
I had to set up a Resource Share that contained my VPC ID and shared it with the requester VPC
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
alternatively, you can share the resource within an OU in your AWS organisation
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Manages a Resource Access Manager (RAM) Resource Share.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
On the peering connection resource, set the argument peer_region
?
https://www.terraform.io/docs/providers/aws/r/vpc_peering.html#peer_region
Provides a resource to manage a VPC peering connection.
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
@loren Since the peering connection is the one from the account I’m creating this, this one does get the region correctly set, the problem comes with the accepting peering connection which doesn’t take in peer_region
but takes in a provider which has the correct region set, but won’t recognize it.
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
@Callum Robertson Thanks!, will try that out and let you know if that helps in this case also.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
What you describe is exactly what peer_region
exists for
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
In the requesting account, it creates the peer request, the request must set the region in which the vpc peering connection will be accepted. you then accept it exactly as you are
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
@loren omg, trying that out right now and I’ll come back with results
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
@Callum Robertson Didn’t get to try your approach since @loren’s solution worked out, I had misunderstood that value and thought it referred to the requester vpc, thank you both again for the help!
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
@Sharanya You can see the code I’m using at the top, hope it helps
data:image/s3,"s3://crabby-images/53780/53780650b090bc251178b89d5a3960134ca4c53a" alt="Patrick Beam avatar"
I’ve been tinkering with this module today. https://github.com/cloudposse/terraform-aws-ec2-instance-group Is there a way to get instances spread across mutiple AZ’s?
Terraform Module for provisioning multiple general purpose EC2 hosts for stateful applications. - cloudposse/terraform-aws-ec2-instance-group
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
One strategy is to provision the module once per AZ
Terraform Module for provisioning multiple general purpose EC2 hosts for stateful applications. - cloudposse/terraform-aws-ec2-instance-group
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
that gives you the most guarantee of even distribution
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
incidentally, this is the strategy that kops
takes when provisioning ASGs for master nodes.
data:image/s3,"s3://crabby-images/53780/53780650b090bc251178b89d5a3960134ca4c53a" alt="Patrick Beam avatar"
Thanks for the response. I like the kops
approach as you do get guaranteed provisioning across AZ’s. It just generates a lot more code but it’s a fair tradeoff.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
yea, it’s a trade off but as you say, probably fair and easy to understand what’s going on.
data:image/s3,"s3://crabby-images/53780/53780650b090bc251178b89d5a3960134ca4c53a" alt="Patrick Beam avatar"
I think it would be nice to have both options. I’ve forked the repo and time permitting i’ll try and add that feature. I do agree though its easier to read. I find this module far less magical
than some of the others I have looked at. Thanks so much for open sourcing and sharing all of these modules.
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
@Patrick Beam you could provide a list of availability zones for that region e.g. [“a”, “b”, “c”] and then in your availability_zone input use this:
data:image/s3,"s3://crabby-images/53780/53780650b090bc251178b89d5a3960134ca4c53a" alt="Patrick Beam avatar"
I think that will work. The problem i’m seeing is with subnet
which is required. I pass the list of subnets created into this module like this.
variable "public_subnet_ids" {}
subnet =var.public_subnet_ids[0]
without that index position terraform throws an error. When I try and create a new variable subnets
with the following.
variable "subnets" {
description = "A list of VPC Subnet IDs to launch in"
type = list(string)
default = []
}
#In the instance resource I changed this.
subnet_id = element(distinct(compact(concat([var.subnet], var.subnets))),count.index,)
#inside the module I set subnet to subnets
subnets = "${var.public_subnet_ids}"
When I plan I get the following error.
Error: Missing required argument
on instances/instance.tf line 18, in module "versio":
18: module "versio" {
The argument "subnet" is required, but no definition was found.
I’m curious how that argument subnet
is required. I don’t understand how that is defined in the module and can’t seem to track that down in the repo.
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
availability_zone = “${element(var.availability_zones, count.index)}”
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
You would just have to change that variable to a type = list(string)
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
hope that helps
2019-08-15
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Anyone with experience in
resource "aws_ssm_document
and after destroy the document does not seems to be deleted
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Having this error on Tf Plan - Error: Missing resource instance key
on .terraform\modules\vpc_peering_cross_account[accepter.tf](http://accepter.tf) line 96, in locals: 96: accepter_aws_route_table_ids = “${distinct(sort(data.aws_route_tables.accepter.ids))}”
data:image/s3,"s3://crabby-images/8f593/8f59375c84cdfbf34fb0776b18e8b900c3c18350" alt="Alejandro Rivera avatar"
@Sharanya I just shared a solution I’m using for vpc peering connection x accounts and x regions that might help a couple of posts up, I’ll tag you
data:image/s3,"s3://crabby-images/e3f98/e3f98827b250d19311a436253c2623814a0fd4da" alt="SweetOps avatar"
Are you using some of our terraform-modules in your projects? Maybe you could leave us a testimonial! It means a lot to us to hear from people like you.
data:image/s3,"s3://crabby-images/9a89a/9a89a0f2b610a31fdde9098ff0b4e84321d62a72" alt="Bharat avatar"
How do i set order precedence in terraform? I have main.tf where it destroys a IAM role and deploy’s it again on terraform-apply. I am hitting a error ` aws_iam_role.service_role: Error creating IAM Role DEFAULT-TestingService-ecs-service-role: EntityAlreadyExists: Role with name DEFAULT-TestingService-ecs-service-role already exists`
This is after destroying the role, pretty sure that AWS needs some time to update the cache.
I want to first destroy the services and then create it. Is this possible?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hmmm…. terraform is used to create resource definitions - how to create them
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
terraform knows from its state file what was created
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
how are you doing destroy
from TF files?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Hi, do you guys have a preference on using the aws KMS managed key or creating a CMK ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the reason I ask that is that after removing Kms_key_id from :
module "ssm_tls_ssh_key_pair" {
source = "git::<https://github.com/cloudposse/terraform-aws-ssm-tls-ssh-key-pair.git?ref=0.2.0>"
namespace = "${var.namespace}"
stage = "${var.stage}"
name = "${var.name}"
attributes = "${var.attributes}"
ssm_path_prefix = "${var.stage}/${var.name}/infrastructure/ssh_keys"
ssh_key_algorithm = "RSA"
ssh_private_key_name = "${module.default_label.id}-private"
ssh_public_key_name = "${module.default_label.id}-public"
#kms_key_id = "${module.kms_key.key_id}"
}
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I got
Error refreshing state: 1 error occurred:
* module.ssm_tls_ssh_key_pair.data.aws_kms_key.kms_key: 1 error occurred:
* module.ssm_tls_ssh_key_pair.data.aws_kms_key.kms_key: data.aws_kms_key.kms_key: error while describing key [alias/test-demo-chamber]: NotFoundException: Alias arn:aws:kms:us-east-1:046894643055:alias/test-demo-chamber is not found.
status code: 400, request id: 7e387954-2256-4ef2-a40e-b48269259e9c
data:image/s3,"s3://crabby-images/1fb14/1fb14ab31f832e7bda3b92cdb72e548471e235b0" alt="Maeghan Porter avatar"
Hey all, I updated the release of terraform-aws-dynamic-subnets that I’m pulling down and now I’m getting this error:
Error downloading modules: Error loading modules: module dynamic_subnets: Error parsing .terraform/modules/e972fa1c1c4c2e3a44d52f7491016697/label.tf: At 3:25: Unknown token: 3:25 IDENT var.attributes
data:image/s3,"s3://crabby-images/1fb14/1fb14ab31f832e7bda3b92cdb72e548471e235b0" alt="Maeghan Porter avatar"
Any idea what’s going on?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for TF 0.12, use release https://github.com/cloudposse/terraform-aws-dynamic-subnets/releases/tag/0.13.0 and newer
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"
Terraform module for public and private subnets provisioning in existing VPC - cloudposse/terraform-aws-dynamic-subnets
data:image/s3,"s3://crabby-images/1fb14/1fb14ab31f832e7bda3b92cdb72e548471e235b0" alt="Maeghan Porter avatar"
oh ok, I’m on TF 0.11.13 and trying to use release 0.16.0 of the module. That must be why then.
data:image/s3,"s3://crabby-images/1fb14/1fb14ab31f832e7bda3b92cdb72e548471e235b0" alt="Maeghan Porter avatar"
I’ll try version 0.12.0
data:image/s3,"s3://crabby-images/1fb14/1fb14ab31f832e7bda3b92cdb72e548471e235b0" alt="Maeghan Porter avatar"
thanks!
data:image/s3,"s3://crabby-images/b82ef/b82efa31774b02e0495c3fd9593957af087dfba0" alt="Joe Presley avatar"
I’m looking to move terraform code for a customer from regular terraform to terraform enterprise. I googled but couldn’t find if there are any quirks or things I should know about TFE. My goal is to create a terraform module that can be used for both the open source version as well as TFE.
data:image/s3,"s3://crabby-images/19c14/19c14a03645a5030703f606f132b98c92107b9e3" alt="igeorgopoulos avatar"
I have an existing aws ecs cluster (made by hand) and would like to update it by using terraform. Is there any documentation for updating existing aws services (alb, ecr, ecs)?
2019-08-16
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
Hi, I am using terraform workspace to create azure windows server’s in more than one environment using one terraform code. For passing hostname and IP address am using the following lookup’s in local
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
locals { location = “${terraform.workspace}” image_id = “${module.image.image_id}” environment = “${module.locals.environment}”
subnets = { eastus2_prod = “${data.terraform_remote_state.shared_networking.eastus2_api_tier_subnet.id}” centralus_prod = “${data.terraform_remote_state.shared_networking.centralus_api_tier_subnet.id}” }
lb_ips = { eastus2_prod = “10.244.160.164” centralus_prod = “10.245.160.164” }
system = {
eastus2_prod = [ {
hostname = "wqilpeap101"
ip = "10.244.160.165" }, {
hostname = "wqilpeap102"
ip = "10.244.160.166" }, ]
centralus_prod = [ {
hostname = "wqilpcap101"
ip = "10.245.160.165" }, {
hostname = "wqilpcap102"
ip = "10.245.160.166" }, ]
}
subnet_id = “${lookup(local.subnets, format(“%s_%s”,local.location, var.environment))}” lb_ip = “${lookup(local.lb_ips, format(“%s_%s”,local.location, var.environment))}” systems = “${lookup(local.system, format(“%s_%s”,local.location, var.environment))}” }
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
it fails with following error message
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
Error: Error asking for user input: 1 error occurred: * local.systems: local.systems: lookup: lookup() may only be used with flat maps, this map contains elements of type list in:
${lookup(local.system, format(“%s_%s”,local.location, var.environment))}
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
can you help me fix this
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@praveen you can try: subnet_id = “${local.subnets[ format(“%s_%s”,local.location, var.environment)]}”
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
subnet is working fine
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
issue is with systems
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
should I try it for systems?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
data:image/s3,"s3://crabby-images/b015f/b015f70078b8973929ac27af853697f66067752e" alt="praveen avatar"
trying now
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
So, I’m trying to be a bit clever. I have a need to conditionally add statements to an IAM policy document
I did try to do a join on the data.aws_iam_policy_document.<stuff>.json
property of multiple data sources, and mixed data sources and already rendered json documents coming in as variables in strings.
I think the root problem with this approach is that both things will render a FULL json document, so it will confuse stuff, such as:
{
my policy doc
}
{
my next policy doc
}
Is there a way to conditionally add statement blocks to a data.aws_iam_policy_document
?
The root cause here is that the cloudposse/terraform-aws-s3-module
has some built in document handling to set an “encrypted-only” policy, so if I need to do something like add a separate cross-account access principal policy, I can’t, because an s3 bucket can only have one bucket policy attached.
I’ve forked it and attempted my above described fix here: https://github.com/asiegman/terraform-aws-s3-bucket/blob/moar-bucket-policy-0.11/main.tf#L94
But alas, that didn’t work due to the multiple json documents being joined to form invalid json.
I can always not use cloudposse’s module and just build my own resources, but if I could add a clever bit to add arbitrary statements in for stuff like this, I was going to deliver it back to the community
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Alex Siegman in 0.12 you can do this with “dynamic” loops. What you could do with 0.11 is using source_json
with another aws_iam_policy_document
. I don’t really like it so much but it’s a funny hack: https://github.com/doingcloudright/terraform-aws-ecr-cross-account/blob/ab55861e4de158d3bf490976c16a2bebb6661c28/main.tf#L43
Terraform module to create an ECR repo with cross-account-access - doingcloudright/terraform-aws-ecr-cross-account
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
Oh interesting. What happens if source json is just a blank string then~? I’ll play with it, great lead. Thanks!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
That won’t work, but you can have one policy statement which would be valid for all your policies, and use that one to start ‘sourcing’ from.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
also take a look at : https://github.com/cloudposse/terraform-aws-iam-policy-document-aggregator
Terraform module to aggregate multiple IAM policy documents into single policy document. - cloudposse/terraform-aws-iam-policy-document-aggregator
data:image/s3,"s3://crabby-images/87b43/87b437757588ae6fd32acd80580a9548a283a76d" alt="Alex Siegman avatar"
heck, i can probably just use that, i already have multiple valid documents, i just need to aggregate all their statements in to one
2019-08-17
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Why did the release cadence change for this module? https://github.com/cloudposse/terraform-aws-vpc/releases
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/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
0.4.2 is a patch release against the last version of the module for terraform 0.11
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/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
0.7.0 is the latest release for 0.12
data:image/s3,"s3://crabby-images/8cce0/8cce0a11bf530b76376be5a645d23f86100318ad" alt="davidvasandani avatar"
Thanks @Erik Osterman (Cloud Posse)
data:image/s3,"s3://crabby-images/0ab29/0ab291e0e3ff8284e1386519ec33455d4c98deda" alt="Norbert avatar"
Hi, I do a bit of TF (0.12) + AWS. I have created a few modules: VPC, Subnets, IGW, etc. Each module outputs.tf some variables, I use S3 backend and I can access exported variables from different modules. All smooth and easy but when I create application load balancer (aws_lb) I can NOT make terraform to output any variable. My output.tf (root module dir) looks like this:
output “alb_id” { value = aws_lb.alb.id } output “alb-security-group_id” { value = aws_security_group.alb-security-group.id } output “alb-target-group_arn” { value = aws_lb_target_group.alb-target-group.arn }
The ALB, security group and target group gets created, I can see it in the console but the output is empty, no errors during terraform apply. Why?
data:image/s3,"s3://crabby-images/7066b/7066b71236984745fac2e8a96ec5cc35585a793c" alt="Barani avatar"
Hi, Anybody using local persistent volume for any kubernetes_stateful_set. I am trying use affinity with ndoe_selector_term but failing. Kindly guide me if anyone using in this way.
2019-08-19
data:image/s3,"s3://crabby-images/8d47e/8d47e333a63b342f2385e9ea8660bdfa54053df5" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Aug 28, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
anybody working with terraform integration with Jenkins cicd pipeline
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we use atlantis
and Codefresh to deploy terraform, but here are a few articles on how to do it from Jenkins
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/d7f58/d7f58b1949c7398a2e00e3fade3993bf96e5f4b3" alt="attachment image"
This extensive article shows you how to create an immutable CI/CD infrastructure with Terraform and Jenkins that will make managing your infrastructure easier.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/0a01b/0a01b6e777f567a79b05922f497568a3796ca4c7" alt="attachment image"
In theory, deploying a dockerised .NET Core app is easy (because Docker simplifies everything, right?). Just trigger your CI/CD pipeline on…
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/9e3fb/9e3fba5acbc5f2d9be74b9f7f496444d911287e5" alt="attachment image"
If you’ve followed my last few posts you have now used Terraform to create a Google Kubernetes Engine cluster, and you’ve deployed Jenkins…
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Hello, I was curious to see if anyone has ever tried to create a cross account aws codepipeline with terraform. If not, It would be great to get some feedback on my current approach
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Does anyone use software to detect state drift on a recurring basis?
I’d like to start performing infrastructure wide Terraform state drift identification, and work towards making sure I see that excellent “No changes.” messaging after issuing a terraform plan
across the board more frequently.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
We just have our CI run terraform plan -detailed-exitcode
, and alert on job failures…
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
I was looking at the detailed-exitcode
option, seems good as I can get an explicit list of terraform projects that are having issues. I’d like to go a step further so I can reduce operator work around identification and fixing of the state drift manually.
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Only saw a few project on GitHub, none of them maintained.
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Check for drift between Terraform definitions and deployed state. - digirati-labs/drifter
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
This one seemed to be the most relevant for my use case.
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Cheap and easy and works was my thinking, can always optimize later
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
Could save off the plan, and analyze it separately. Maybe whitelist some resources/diffs to run apply automatically
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
The Foqual bot was able to find some information regading GitHub Actions to perform plans, could be a good starting point for me.
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Yeah, very much MVP for this drift detector - iterate later
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Thanks for the ideas, I’ll think about this some more and see how to approach this
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
Hi, should this module : https://github.com/cloudposse/terraform-aws-cloudwatch-logs when a CMK key gets passed to create a policy to be able to use that key ?
2019-08-20
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Hi All, I’m creating a bucket policy data resource (https://www.terraform.io/docs/providers/aws/r/s3_bucket_policy.html)
I’m running into an issue where I’m trying to reference the ‘json’ attribute of the data source in a policy account resource, can anyone help me with the below?
Attaches a policy to an S3 bucket resource.
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
I’m getting the error that it’s an empty tuple, not sure what I’m doing wrong here..
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Callum Robertson what about you do at line16 the same as line 2, so the count’s are in sync
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
or what is the idea there, that you only want to apply the policy when var.upload_bucket_objects is set to true, correct ? What happens now is that you refer to a policy you are not creating hence it fails.
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
encountered the following error when running terraform apply?
[3:57 PM] “policy” contains an invalid JSON: invalid character ‘a’ looking for beginning of value
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
You’d have to paste your policy here for further debugging. Seems like a syntax or formatting issue.
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
Also not sure what provider this is for?
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
AWS, Google Cloud, Sentinel?
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
If you are using AWS, this tool has helped me in the past for creating sane policy document templates:
data:image/s3,"s3://crabby-images/7526d/7526d6efd1131aee191722e42f697638199cfd7c" alt="mpmsimo avatar"
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Thanks That helped
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
Thanks @maarten, I think it’s the case of starting at a problem for to long
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
data:image/s3,"s3://crabby-images/1294a/1294a3c1025376cf58bdd22bac409db3a48e9c3e" alt="Callum Robertson avatar"
2019-08-21
data:image/s3,"s3://crabby-images/6d386/6d3867f3e7ff62baf85d66f65daf00059a0f3451" alt="pericdaniel avatar"
Can’t recall but when you create an AWS SG rule with terraform and you do something like count index vs creating separate rules, which one doesn’t delete the whole sg and create a new one? Instead of creating a new sg every time I’d like to just keep adding/removing ports if needed.
from_port = "80"
vs
from_port = var.allowed_ports[count.index]
I know in your tf you do the second one. let me know! Thank you!
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@pericdaniel when you create a separate aws_security_group
w/o rules, you can add as many aws_security_group_rule
as you need w/o recreating the whole SG
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an Elastic MapReduce (EMR) cluster on AWS - cloudposse/terraform-aws-emr-cluster
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#office-hours starting now! https://zoom.us/j/508587304
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
Curious, are you all using or looked into dependabot for terraform module dependencies - https://dependabot.com/terraform/
Automated dependency updates for your Ruby, Python, JavaScript, PHP, .NET, Go, Elixir, Rust, Java and Elm.
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
for the cloudposse modules, I got all these working with 0.12: https://github.com/cloudposse/terraform-aws-ec2-autoscale-group/pull/14 https://github.com/cloudposse/terraform-aws-eks-workers/pull/21 https://github.com/cloudposse/terraform-aws-eks-cluster/pull/20
I forgot to update the version for CI to 0.12, will try and push that out
This moves us to terraform 0.12, it is working with our usages of this module, but it hasn't been tested completely with all options, but does appear valid. note that the examples aren't po…
Note, this depends on cloudposse/terraform-aws-ec2-autoscale-group#14 getting merged and then making a change here to reference that new tag. This does the upgrade and also copies the new arguments…
This moves this module to terraform 0.12, the example isn't ported, as some of those modules aren't 0.12 compliant yet, but this is working with our EKS clusters. I notice there are also te…
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
I am using them and they are working
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
but could use some help to get the rest of the work done (porting examples and adding the new CI stuff)
data:image/s3,"s3://crabby-images/d9af7/d9af7ef675a6053f6eb63d867f8d257af29a972e" alt="Addison Higham avatar"
except… looking around, I have no idea how to get it 0.12 to run as part of the things
2019-08-22
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Error: The role “arniam:role/gc-invoicedataimport-function-role” cannot be assumed.
There are a number of possible causes of this - the most common are:
* The credentials used in order to assume the role are invalid
* The credentials do not have appropriate permission to assume the role
* The role ARN is not valid
data:image/s3,"s3://crabby-images/cceb1/cceb1cf10c798fde397856859a028141b903f068" alt="Sam avatar"
IMPORTANT: Upcoming change to AWS Cost and Usage Report Access Control Policies on August 19th
2019-08-23
data:image/s3,"s3://crabby-images/cfc7a/cfc7a4b2305864b027d17c0c546a24a389e09eef" alt="Chad Hartman avatar"
Do you need to use version Terraform 0.11 when bootstrapping with the reference-architectures?
data:image/s3,"s3://crabby-images/da438/da4385e80b814e7e1ef13d226fcf4bba1ef83fde" alt="gk avatar"
Hey folks. Is there a way to use a merge or use a splat-type operator in a terraform child block (not identifier values) ? i.e.
data "aws_ami" "potato" {
filter {
...local.default_filters
}
}
data:image/s3,"s3://crabby-images/da438/da4385e80b814e7e1ef13d226fcf4bba1ef83fde" alt="gk avatar"
I’m effectively trying to filter merge(local.thing, {})
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
So, when you’re creating an ECS service, you either have the choice between using an ALB or not.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
If you’re using an ALB, you need to pass in additional objects for the load_balancer
parameter, example here: https://www.terraform.io/docs/providers/aws/r/ecs_service.html#example-usage
Provides an ECS service.
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
How would you structure a module to make this object parameterized and optional?
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
I guess this kind of answers my question: https://github.com/blinkist/terraform-aws-airship-ecs-service/blob/master/modules/ecs_service/main.tf
Terraform module which creates an ECS Service, IAM roles, Scaling, ALB listener rules.. Fargate & AWSVPC compatible - blinkist/terraform-aws-airship-ecs-service
data:image/s3,"s3://crabby-images/17c19/17c198162babe5ef0242fce2ead5561b10cc8803" alt="cabrinha avatar"
just create a ton of these different ecs_service resources based on how they’re configured.
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
The variable “lambda_settings” is required, so Terraform cannot proceed without a defined value for it. “ - any idea about this
2019-08-26
data:image/s3,"s3://crabby-images/8d47e/8d47e333a63b342f2385e9ea8660bdfa54053df5" alt="Cloud Posse avatar"
:zoom: Join us for “Office Hours” every Wednesday 11:30AM (PST, GMT-7) via Zoom.
This is an opportunity to ask us questions on terraform
and get to know others in the community on a more personal level. Next one is Sep 04, 2019 11:30AM.
Register for Webinar
#office-hours (our channel)
data:image/s3,"s3://crabby-images/a9fa6/a9fa6c642c2cffbe20ec9a71522b08dac940c5da" alt="party_parrot"
2019-08-27
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Hey all! New to terraform, I’m trying to do some acm cert validation using : https://www.terraform.io/docs/providers/aws/r/acm_certificate_validation.html
In the link, they show the following r53 record for cert validation being created:
resource "aws_route53_record" "cert_validation" {
name = "${aws_acm_certificate.cert.domain_validation_options.0.resource_record_name}"
type = "${aws_acm_certificate.cert.domain_validation_options.0.resource_record_type}"
zone_id = "${data.aws_route53_zone.zone.id}"
records = ["${aws_acm_certificate.cert.domain_validation_options.0.resource_record_value}"]
ttl = 60
}
Specifically, aws_acm_certificate.cert.domain_validation_options.0.resource_record_name
, I create my acm certs(Specifically 2) like this:
resource "aws_acm_certificate" "cert" {
provider = "aws.acm"
domain_name = "*.${var.domain}.${element(var.certs, count.index)}.${var.aws_env == "prod" ? "com." : "test."}"
validation_method = "DNS"
tags = "${local.required_tags}"
lifecycle {
create_before_destroy = true
}
count = "${length(var.certs)}"
}
How would I be able to reference each cert for validation?
Waits for and checks successful validation of an ACM certificate.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
Terraform module to request an ACM certificate for a domain name and create a CNAME record in the DNS zone to complete certificate validation - cloudposse/terraform-aws-acm-request-certificate
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
This might serve as a good reference point.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
oh this looks like a good idea, thank you
data:image/s3,"s3://crabby-images/fae68/fae68ef6d65ecb3e38809cc5ccb1e419e4f5b29d" alt="mrwacky avatar"
This looks correct
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
what looks correct?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I dont know how to reference each cert for validation
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@Brij S you are missing a resource - let me find it
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
ah, I see what you mean … you will need to somehow loop over all of your certs and specify a aws_acm_certificate_validation
resource for each one…
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yeah.. thats the tricky part
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
not sure how to facilitate that
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@Brij S are you using terraform 0.12+?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
no, TF 0.11
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
it might be impossible to do this, since the count
for resource "aws_route53_record" "cert_validation"
will not be able to be <computed>
, i.e. can’t dynamically set to the cert count iirc
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
What are you guys toughs on Terraform enterprise ?
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@johncblandii
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I like it. I think there are some corners for sure where they could improve, specifically around integrating with other systems without creating custom CLI solutions
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
PR integration is legit
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
private module registry is almost a requirement if you plan on having modules live in their own repos, the dependency management between all of them using just git tagging (only option non-enterprise) is such a pita
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
yeah, it definitely can be
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
i can demo any parts of it to anyone who wants to check it out
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
we terraformed all of our workspaces so all projects are basically just reusable TF modules
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I will interested on that demo for sure
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@johncblandii so you aren’t using workspaces for separation between environments? or did i read that wrong
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
we are
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
dev, uat, support, prod, training, etc
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
@jose.amengual email me: [email protected]
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
i read somewhere (i think official docs) that workspaces shouldn’t be used for this but they just work so perfectly for DRY
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
TFE is workspaces
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
literally
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
yea my guess is outdated docs or it wasn’t official and im mistaken
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Terraform by HashiCorp
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
oh and the remote execution is legit
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
such a timesaver for devs who don’t have write access to prod to test fixes with prod secrets
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
write locally, use vars configured on Cloud
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
is it worth it ?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@sarkis right! that makes sense, any thoughts on how to go forward with this then
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
@Brij S i’d say if you want to continue to go with this dynamically, TF 0.12 upgrade may be the only option… otherwise only way I can think of solving this in 0.11 is to have static cert_validations - hopefully someone can prove me wrong here
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
ok, if I was on TF 0.12, how would you go about it
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you just count over the variable input again, length(var.certs)
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
but how would i reference it?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
aws_acm_certificate.cert.domain_validation_options.0.resource_record_name
refers to..one cert?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
you want to create a route53 record for each certificate?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yep
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
because for me aws_acm_certificate.cert
contains two certs (corresponding to two zones)
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
resource "aws_route53_record" "cert_validation" {
count = "${length(var.certs)}"
name = "${aws_acm_certificate.cert.domain_validation_options.*.resource_record_name[count.index]}"
type = "${aws_acm_certificate.cert.domain_validation_options.*.resource_record_type[count.index]}"
zone_id = "${data.aws_route53_zone.zone.id}"
records = ["${aws_acm_certificate.cert.domain_validation_options.*.resource_record_value[count.index]}"]
ttl = 60
}
data:image/s3,"s3://crabby-images/d2dcf/d2dcfacd6b731bfc0f85081aafea45f2bfd433ba" alt="ciastek avatar"
I had a problem with domain_validation_options
when using multiple names from aws_acm_certificate
resource - the order of domain_validation_options
were undefined. Not sure if it’s still a problem.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@loren this is awesome, would the following be the same too then?
resource "aws_acm_certificate_validation" "cert" {
certificate_arn = "${aws_acm_certificate.cert.arn}"
validation_record_fqdns = ["${aws_route53_record.cert_validation.fqdn}"]
}
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
something like that, can also use element(...)
interpolation
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
need the wildcard to reference all the resources…
resource "aws_acm_certificate_validation" "cert" {
certificate_arn = "${aws_acm_certificate.cert.arn}"
validation_record_fqdns = ["${aws_route53_record.cert_validation.*.fqdn}"]
}
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
there are also more syntax options in terraform 0.12
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
"${aws_acm_certificate.cert.arn}"
would be "${aws_acm_certificate.cert.*.arn[count.index]}"
?
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
validation_record_fqdns
is a list, so i think you want a single resource there, not multiple with count. just pass the list of all fqdns to the parameter, rather than a single one (using count.index
)
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
if you do want a aws_acm_certificate_validation
resource per cert though, then yes, same setup
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@loren mind if I DM you for more questions? Just want to confirm some things to make sure I understand
data:image/s3,"s3://crabby-images/b2ee3/b2ee3ca080f64d8b69284d7f2d54d1b8bb5013b6" alt="loren avatar"
of course, i may not be online to respond quickly though. kinda doing this in between work tasks
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
Hi Guys
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
I have some issue when running terraform validdate on this modules terraform-null-label
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
hi @Phuc
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
Does anyone expenrienced this before ?
terraform-null-label git:(0.11) ✗ terraform validate
Error: local.generated_tags: local.generated_tags: zipmap: count of keys (1) does not match count of values (0) in:
${zipmap(
compact(list("Name", local.namespace != "" ? "Namespace" : "", local.environment != "" ? "Environment" : "", local.stage != "" ? "Stage" : "")),
compact(list(local.id, local.namespace, local.environment, local.stage))
)}
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
I didn’t adjust anything
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
just running simple command to validate at first
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what TF version?
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
for 0.11 and below
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
I clone the repo on branch 0.11/master
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
how do you use it? show the example
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
actually I didn’t used it yet
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
I just try to validate the code first to see if there is error
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
just simple terraform init then terraform validate
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
and that error coming up
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you need to validate module invocation with all vars provided, similar to https://github.com/cloudposse/terraform-null-label/blob/0.11/master/examples/complete/main.tf
Terraform Module to define a consistent naming convention by (namespace, stage, name, [attributes]) - cloudposse/terraform-null-label
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
thank @Andriy Knysh (Cloud Posse), I will try to follow that
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
Hi aknysh
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
Just a smal question need you to answer
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
I see there is 2 modules: terraform-label and terraform-null-label on github of cloudposse
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
It seems they are all for naming conversion.
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
so what is the difference between those modules ?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
null-label
and terraform-label
are mostly the same in terms of naming convention and generating globally unique IDs for AWS resources
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
null-label
has much more features, e.g. context, additional tags as list of maps outputs, etc.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but with TF 0.11, all that complex logic in null-label
was sometimes throwing the count can't be computed errors
in top-level modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s why we created a simplified version of it and named it terraform-label
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so if you just need a naming convention and globally unique IDs, both could be used
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
but both were converted to TF 0.12 now, so null-label
should be OK to use (much less count can't be computed
errors`
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
so try null-label
with TF 0.12, it has more features
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(but both modules are supported)
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
thank Akysh, due to current TF 0.11, I think I will test with null-label
data:image/s3,"s3://crabby-images/15ef2/15ef26a367a44ae409b2dc44233f5a0b9e694613" alt="Kiran avatar"
@Andriy Knysh (Cloud Posse) Is there any possibility to support TF12 for https://github.com/cloudposse/terraform-aws-ec2-bastion-server module ? I can’t find any issue regarding this?
Terraform Module to define a generic Bastion host with parameterized user_data - cloudposse/terraform-aws-ec2-bastion-server
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes, we’ll convert it. Did not have time yet, we have more than 100 modules, converted 40+ so far
Terraform Module to define a generic Bastion host with parameterized user_data - cloudposse/terraform-aws-ec2-bastion-server
data:image/s3,"s3://crabby-images/15ef2/15ef26a367a44ae409b2dc44233f5a0b9e694613" alt="Kiran avatar"
Thanks for the prompt response
2019-08-28
data:image/s3,"s3://crabby-images/15ef2/15ef26a367a44ae409b2dc44233f5a0b9e694613" alt="Kiran avatar"
Can I know estimation time for this PR to be merged - https://github.com/cloudposse/terraform-aws-multi-az-subnets/pull/16 ? Also TravisCI is failing because it checks this TF12 upgrade PR in TF11 binary.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we will review it ASAP. We started converting the module to 0.12, but did not have time to finish it. We also adding tests for the module and for the example (bats and terratest) and Codefresh Ci/CD pipelines to deploy the example on AWS account
data:image/s3,"s3://crabby-images/15ef2/15ef26a367a44ae409b2dc44233f5a0b9e694613" alt="Kiran avatar"
Sounds good Thanks buddy.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Hello all, I’m trying to do acm cert validation(multiple at a time) and I’m running into some issues.
resource "aws_route53_record" "cert_validation" {
count = length(var.certs)
name = aws_acm_certificate.cert[count.index].domain_validation_options.0.resource_record_name
type = aws_acm_certificate.cert[count.index].domain_validation_options.0.resource_record_type
zone_id = aws_route53_zone.zones[count.index].id
records = ["${aws_acm_certificate.cert[count.index].domain_validation_options.0.resource_record_value}"]
ttl = 60
}
the above code..kinda works? when I apply this, I get the following error:
Error: Invalid index
on ../modules/bootstrap/acm_validation.tf line 4, in resource "aws_route53_record" "cert_validation":
4: type = aws_acm_certificate.cert[count.index].domain_validation_options.0.resource_record_type
|----------------
| aws_acm_certificate.cert is tuple with 2 elements
| count.index is 0
The given key does not identify an element in this collection value.
Error: Invalid index
on ../modules/bootstrap/acm_validation.tf line 6, in resource "aws_route53_record" "cert_validation":
6: records = ["${aws_acm_certificate.cert[count.index].domain_validation_options.0.resource_record_value}"]
|----------------
| aws_acm_certificate.cert is tuple with 2 elements
| count.index is 0
The given key does not identify an element in this collection value.
Error: Invalid index
on ../modules/bootstrap/acm_validation.tf line 6, in resource "aws_route53_record" "cert_validation":
6: records = ["${aws_acm_certificate.cert[count.index].domain_validation_options.0.resource_record_value}"]
|----------------
| aws_acm_certificate.cert is tuple with 2 elements
| count.index is 0
The given key does not identify an element in this collection value.
But when I do destory, it seems its creating at least 1..
module.nonprod.aws_route53_record.cert_validation[1]: Still destroying... [id=Z3FZBH8XNPPPYT__3aedbf37656ebde46d6db19a4f38212c.test-api.dev._CNAME, 30s elapsed]
module.prod.aws_route53_record.cert_validation[1]: Still destroying... [id=Z2IAS5UODUXPHA__73016316fbab15ae3d5db4d2b9b240c8.test-api.com._CNAME, 30s elapsed]
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
any ideas?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what version of TF? what’s type of var.certs
? If it’s a list of string, how many items are in it?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
Terraform v0.12.5
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
variable "certs" {
default = ["apps", "api"]
type = "list"
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you are mixing TF 0.11 code with TF 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that’s why it’s not working
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
(yes, TF is not so smart)
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
oh, what do you mean
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
like my var is setup wrong?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
var types and interpolations in TF code
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
im not sure I follow, what would I need to change?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
not sure if that’s the reason of the errors, but first convert everything to TF 0.12 syntax
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
type = list(string)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
0.12 ^
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
thank you both! indeed wizards. Wouldve never noticed the 11 vs 12 syntax. D’oh
data:image/s3,"s3://crabby-images/56511/565110c5baaf97fce995c805ec750f2d59d84cc8" alt="sarkis avatar"
just went to the top of my TF debug playbook as well - thanks to @Andriy Knysh (Cloud Posse)
data:image/s3,"s3://crabby-images/1f112/1f1120d7c318c548190b06c33109a6e54d94c908" alt="Igor avatar"
Saw on Reddit: https://www.reddit.com/r/Terraform/comments/cwgy7r/i_created_a_visualizer_for_terraform_project_cc/
10 votes and 2 comments so far on Reddit
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
#office-hours starting now! join us here https://zoom.us/s/508587304
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
how would this line be turned into ‘tf 12 syntax
“*.${var.domain}-${element(var.certs, count.index)}.${var.aws_env == “prod” ? “com.” : “dev.”}”`
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
it’s already TF 0.12 syntax since you are using string concatenation with interpolation
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yes, I ran the terraform12 upgrade command and it didnt change
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
also you could use this: format("*.%s-%s.%s", var.domain, var.certs[count.index], var.aws_env == "prod" ? "com." : "dev.")
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
whatever looks better for you
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
oh cool, didnt know I could do that
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
thank you again !!
data:image/s3,"s3://crabby-images/014e4/014e4b7974f221e4284156ba414e42adc0328a62" alt="Chris Montes avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
did not see it before
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can try to run terraform taint
data:image/s3,"s3://crabby-images/fbf7c/fbf7c958fe5e17349c00227aff72d3503eadd2a1" alt="Joshua Snider avatar"
Hi everyone! We are currently using the terraform-null-label module for labels in Terraform but we are running into an issue when updating our code to v0.12 We pass “context” between modules so we have a variable defined in the module called “tags_context” and type: map This was upgraded to type: map(string) by Terraform but then the plan doesn’t work What type should the context variable be in v0.12?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
@Joshua Snider see #announcements
data:image/s3,"s3://crabby-images/fbf7c/fbf7c958fe5e17349c00227aff72d3503eadd2a1" alt="Joshua Snider avatar"
nvm, it was answered in #announcements
data:image/s3,"s3://crabby-images/19811/198113f18589f3d13f65b6072ac4bb9b4d510c05" alt="Sharanya avatar"
Did anyone Come across NPM memory Issues ?
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Hey folks! I see that there’s a Cloud Posse container definition module, but I’m wondering if there’s an easy way to make a container_definition a reusable variable (or similar) that still supports interpolation. Use case: I have an ECS service that I run as both Fargate and EC2 using two different modules and don’t want to duplicate the container definition to keep it dry.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
the container definition for Fargate and ECS are slightly different
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
in Fargate the Task have to set memory and CPU and the container definition too
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but in ECS EC2 that is not required
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and there is some other differences on the network setup etc
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I think is sane to have them separated
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Hmmm, with 15+ envvars/secrets and 4 environments it feels very anti-dry to repeat it so many times.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you have them in variables ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
what is so not DRY about that ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
if you had them hardcoded I will agree
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
and you have 4 environments ?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so if you separate those for ENVs in it’s own TF
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
would you call it DRY ?
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
In my structure I have a directory per env for an application
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we have some cluster with like 20 different task defs
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Perhaps I should switch to using tfvars?
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but in reality they should be it’s own thing
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I use tfvars
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Hmmm
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
I think if I reassessed how I structured this it would help my DRY concerns
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Thanks for the feedback
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
we populate the tfvar from SSM parameter store
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
when necesary
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
or jenkins does it
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
from other secret/parameter store
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Does it automatically create the tfvars based on what is in parameter store? I have my secrets name spaced with app/env/secret_name and was thinking I could write something to automatically grab all the params set for an app and put together the secrets block
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
you can use chamber for that
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
CLI for managing secrets. Contribute to segmentio/chamber development by creating an account on GitHub.
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
so you can do something like
chamber write test-ec2-helloworld ecs_parameter_secret password333
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
where
test-ec2-helloworld
is your app/service
data:image/s3,"s3://crabby-images/b052b/b052b3d7f5734f88c7956ab1e98868f9977cc02c" alt="Daniel avatar"
Very interesting
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
chamber export test-ec2-hello -f tfvars 1350ms Wed 28 Aug 15:42:11 2019
ecs_parameter_secret = "password1"
ecs_parameter_string = "NOTSECRET"
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
or you can use chamber as ENTRYPOINT in your containers
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
but I don’t know how usefull is that since now you can use SM or SSM parameter store directly in the task def
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I’m trying to use a local variable as the bucket name:
resource "aws_s3_bucket" "remote_state" {
bucket = local.bucket_name
force_destroy = var.force_destroy
acl = "private"
versioning {
enabled = var.versioning_enabled
}
tags = local.required_tags
}
local var is :
locals {
bucket_name = "account-${var.aws_env}-${project_domain}-${var.aws_region}"
}
but when I try to run terraform plan
I get the following error:
50: bucket_name = "account-${var.aws_env}-${project_domain}-${var.aws_region}"
A reference to a resource type must be followed by at least one attribute
access, specifying the resource name.
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
what does that mean?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Missing var in project_domain
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
missing var?
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I have project_domain declared as a var
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
var.project_domain
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
omg!
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Use a good editor with TF error detection, like JetBrains IDEA with TF plugin, or VS Code
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I use vscode with the terraform plugin
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
ive been told its ‘alright’ though
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
it seems that this example : https://github.com/cloudposse/terraform-aws-rds-cluster/blob/master/examples/enhanced_monitoring/main.tf#L17 is not correct
Terraform module to provision an RDS Aurora cluster for MySQL or Postgres - cloudposse/terraform-aws-rds-cluster
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
does not work on TF 0.12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Maybe, only examples/complete tested in 0.12 and have automatic tests for them
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I had to do
assume_role_policy = "${data.aws_iam_policy_document.enhanced_monitoring.json}"
to make it work
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
which I found it weird
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
I’m new to 0.12 and I posted this in the 0.11 channel
data:image/s3,"s3://crabby-images/afcda/afcdaf6c850e24589d88452e0bf9448a38682f9c" alt="jose.amengual avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Weird indeed
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
@Andriy Knysh (Cloud Posse) one more question if you dont mind! I have a module declaration as follows:
module "s3-remote-state-bucket" {
source = "../../modules/remote_state"
versioning_enabled = var.versioning_enabled
force_destroy = var.force_destroy
aws_env = "nonprod"
aws_region = var.aws_region
aws_account_id_nonprod = var.aws_account_id_nonprod
aws_account_id_prod = var.aws_account_id_prod
providers = {
aws = "aws.nonprod"
}
}
in my variables.tf file in the same folder I have:
variable "aws_env" {
description = "aws account environment"
type = string
}
Note: no default value. but when I run apply I get asked for the aws_env:
terraform apply
var.aws_env
aws account environment
Enter a value:
I dont want to use a default variable for this, this worked as intended with tf11 - anything new with tf12 maybe?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Don’t believe 0.11 didn’t ask you for a missing value :)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Nothing changed in 0.12
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
im providing it in the module declaration though, strange
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
But maybe the var value was provided in tfvar file, or on command line, or in ENV var
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
huh, so if I remove it from the vars file and provide the value it works as intended
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
wild..
2019-08-29
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
hi Guys, I have some issue when running test on module creating s3
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
Here is the code in my main file
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
module "s3_bucket" {
source = "git:xxxxx/terraform-modules/aws-s3.git?ref=terraform_0.11"
enabled = "true"
user_enabled = "false"
allowed_bucket_actions = []
policy = ""
force_destroy = "false"
versioning_enabled = "true"
allow_encrypted_uploads_only = "false"
sse_algorithm = "AES256"
kms_master_key_arn = ""
namespace = "test"
name = "frontend"
stage = ""
attributes = []
delimiter = "-"
tags = {
"BusinessUnit" = "XYZ",
"Snapshot" = "true"
}
}
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
and here is in variables.tf
variable "namespace" {
type = "string"
#default = ""
description = "Namespace (e.g. `eg` or `cp`)"
}
variable "stage" {
type = "string"
#default = ""
description = "Stage (e.g. `prod`, `dev`, `staging`)"
}
variable "name" {
type = "string"
#default = ""
description = "Name (e.g. `app` or `db`)"
}
variable "delimiter" {
type = "string"
default = "-"
description = "Delimiter to be used between `namespace`, `stage`, `name` and `attributes`"
}
variable "attributes" {
type = "list"
default = []
description = "Additional attributes (e.g. `1`)"
}
variable "tags" {
type = "map"
default = {}
description = "Additional tags (e.g. `{ BusinessUnit = \"XYZ\" }`"
}
variable "acl" {
type = "string"
default = "private"
description = "The canned ACL to apply. We recommend `private` to avoid exposing sensitive information"
}
variable "policy" {
type = "string"
default = ""
description = "A valid bucket policy JSON document. Note that if the policy document is not specific enough (but still valid), Terraform may view the policy as constantly changing in a terraform plan. In this case, please make sure you use the verbose/specific version of the policy."
}
variable "region" {
type = "string"
default = ""
description = "If specified, the AWS region this bucket should reside in. Otherwise, the region used by the callee."
}
variable "force_destroy" {
type = "string"
default = "false"
description = "A boolean string that indicates all objects should be deleted from the bucket so that the bucket can be destroyed without error. These objects are not recoverable."
}
variable "versioning_enabled" {
type = "string"
default = "false"
description = "A state of versioning. Versioning is a means of keeping multiple variants of an object in the same bucket."
}
variable "sse_algorithm" {
type = "string"
default = "AES256"
description = "The server-side encryption algorithm to use. Valid values are `AES256` and `aws:kms`"
}
variable "kms_master_key_arn" {
type = "string"
default = ""
description = "The AWS KMS master key ARN used for the `SSE-KMS` encryption. This can only be used when you set the value of `sse_algorithm` as `aws:kms`. The default aws/s3 AWS KMS master key is used if this element is absent while the `sse_algorithm` is `aws:kms`"
}
variable "enabled" {
type = "string"
description = "Set to `false` to prevent the module from creating any resources"
default = "true"
}
variable "user_enabled" {
type = "string"
default = "false"
description = "Set to `true` to create an S3 user with permission to access the bucket"
}
variable "allowed_bucket_actions" {
type = "list"
default = ["s3:PutObject", "s3:PutObjectAcl", "s3:GetObject", "s3:DeleteObject", "s3:ListBucket", "s3:ListBucketMultipartUploads", "s3:GetBucketLocation", "s3:AbortMultipartUpload"]
description = "List of actions the user is permitted to perform on the S3 bucket"
}
variable "allow_encrypted_uploads_only" {
type = "string"
default = "false"
description = "Set to `true` to prevent uploads of unencrypted objects to S3 bucket"
}
`
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
the issue is, if I run terraform validate to see the resource which will be created. I will come up with this error :
Test_s3_module terraform validate
Error: Required variable not set: namespace
Error: Required variable not set: stage
Error: Required variable not set: name
but I already declared the value for each of that value in main.tf this error wont show up if I put default value under the variables file like this:
variable "namespace" {
type = "string"
default = "" <------ this line
description = "Namespace (e.g. `eg` or `cp`)"
}
variable "stage" {
type = "string"
default = "" <------ this line
description = "Stage (e.g. `prod`, `dev`, `staging`)"
}
variable "name" {
type = "string"
default = "" <------ this line
description = "Name (e.g. `app` or `db`)"
}
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
I’m testing on TF v0.11
data:image/s3,"s3://crabby-images/63685/63685d70060f867ea3b89fac84cb6db768e505fb" alt="Phuc avatar"
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
has anyone tried github actions for terraform? https://www.terraform.io/docs/github-actions/getting-started/index.html
Terraform by HashiCorp
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I’m actually looking to do this soon. I get tired of having people re-commit/push due to TF fmt failing on CI. Looking to automate an fmt commit.
Terraform by HashiCorp
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
yeah, I followed their getting started……but it doesnt work
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
(unsure if possible, but i’m going to try it out soon)
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
it is possible according to their docs
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
welp…then there is that
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
but I set it up to be invoked on PR’s
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
I tried it last night and it didnt even work
data:image/s3,"s3://crabby-images/be9b7/be9b784e8673741ab337b638f00a4d5cbd41b1c2" alt="Brij S avatar"
their documentation is a bit confusing
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I’m a bit flummoxed. I have a 00_remote_state.tf
file that I’ve used all over the place that configures s3 for remote state for various vanilla terraform projects. I’m trying to use it now in a new project. terraform init
downloads the latest aws plugin and says it succeeds, but it’s not creating the key (dns-nonprod/terraform.tfstate
) that I’ve told it to up in the S3 bucket. I swear this used to work. Shouldn’t terraform init create the key up in s3? Running any terraform plan or terraform apply errors with state not found:
data.terraform_remote_state.ops_s3: Refreshing state...
data.aws_route53_zone.qa_example_net: Refreshing state...
data.aws_route53_zone.qa2_example_net: Refreshing state...
data.aws_route53_zone.dev_example_net: Refreshing state...
Error: Unable to find remote state
on 00_remote_state.tf line 1, in data "terraform_remote_state" "ops_s3":
1: data "terraform_remote_state" "ops_s3" {
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Does this behavior sound familiar to anybody?
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I have tried forcing older aws plugin version that worked fine previously. 2.19 and 2.14 (2.25 is latest). No change in behavior. I can paste the file here if requested. It’s just not making any sense to me.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- terraform versions are the same or different?
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Running terraform 0.12.4, same as I have been for weeks.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Thanks for the feedback, BTW.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
- Does the user you are using to provision have the permissions to access the remote state?
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I just created a file in that S3 bucket, and then deleted it. I do have create access.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I ran the init with TF_LOG=debug
. I see it checks if the file exists up in S3. But then it never tries to create it.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
question: I am trying to build a module wrapping a resource and don’t want to provide every single argument for the resources blocks.
resource "type" "name" {
some_block {
blah = true
}
}
I want to instead say:
resource "type" "name" {
some_block = var.some_block
}
I did see possibly using a loop, but I’m not seeing a definitive answer or direction.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
dynamic blocks (TF 0.12 only)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Terraform module to provision an Elastic MapReduce (EMR) cluster on AWS - cloudposse/terraform-aws-emr-cluster
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
perfect
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if the var is not a list of objects (and you don’t want i to be a list), then you could do something like this:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
dynamic "bootstrap_action" {
for_each = [var.bootstrap_action]
content {
path = bootstrap_action.value.path
name = bootstrap_action.value.name
args = bootstrap_action.value.args
}
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you want conditionally add the block depending on some bool expression:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
dynamic "bootstrap_action" {
for_each = var.add_block ? [var.bootstrap_action] : []
content {
path = bootstrap_action.value.path
name = bootstrap_action.value.name
args = bootstrap_action.value.args
}
}
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
nice
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
so we still need to define the content
of each individual one, but we do not need to worry w/ defining all vars
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
that’s lovely
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
and this works with blocks of blocks?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
can you for_each
in a content
block?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
yes
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
good deal
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
spot check (if you don’t mind):
resource "aws_msk_cluster" "this" {
cluster_name = var.cluster_name
kafka_version = var.kafka_version
number_of_broker_nodes = var.number_of_broker_nodes
tags = var.tags
dynamic "client_authentication" {
for_each = var.client_authentication
content {
dynamic "tls" {
for_each client_authentication.tls
content {
certificate_authority_arns = client_authentication.tls.value.certificate_authority_arns
}
}
}
}
}
https://www.terraform.io/docs/providers/aws/r/msk_cluster.html
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
var.client_authentication
should be list(object)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
tls
inside it should be list(string)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
and add this:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
dynamic "tls" {
for_each = toset(client_authentication.value.tls)
iterator = item
content {
certificate_authority_arns = item.value.certificate_authority_arns
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
TF 0.12 has difficulties with list(string)
, needs it to be set(string)
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
so i take it we need to flesh out the object
in the variable declaration as well?
Error: Invalid type specification
on ../variables.tf line 18, in variable "client_authentication":
18: type = list(object)
The object type constructor requires one argument specifying the attribute
types and values as a map.
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"
Terraform module to provision an Elastic MapReduce (EMR) cluster on AWS - cloudposse/terraform-aws-emr-cluster
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
@Andriy Knysh (Cloud Posse) I thought I had found it.
In my s3.conf used for terraform init -backend-config=s3.conf
, I had put dns-nonprod/terraform.tfstate
.
And in my [00_remote_state.tf](http://00_remote_state.tf)
, I had put dns_nonprod/terraform.tfstate
.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I fixed the second one, and now it’s giving me the same error. This is perplexing, still working through it. Thanks for the sanity questions previously.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
In my s3.conf, I have:
bucket = "foo"
key = "dns-nonprod/terraform.tfstate"
region = "us-east-1"
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Is it possible to make the terraform_remote_state
configuration read that in for the config = { ... }
section? I hate having two different sources of truth (one for terraform init - the s3.conf, and one for everything else)
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
@Robert has joined the channel
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
@Todd Lyons with the consul backend you can do something like this:
terraform {
backend "consul" {
address = "consul.vault:8500"
scheme = "http"
path = ""
}
}
export BACKEND_KEY=project/environment/name
terraform init -backend-config="path=$BACKEND_KEY" "$TERRAFORM_DIR"
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
Maybe you could do the same with the key
.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I apologize, but I don’t quite understand the “do the same with the key
” comment. I’m still experimenting though, I may get better results now that I’m no longer dealing with the chicken/egg issue.
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
No worries
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
data:image/s3,"s3://crabby-images/7ff54/7ff54a25810b5ef127025d5d2e316b6aa4191e3f" alt="Robert avatar"
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
It sounds like I can only do it with something remote, not a local file. I tried reading it in using the local_file resource and then all manner of tomap() and split() and such things. Some things flat out errored, some things acted like they were going to work but then complained about the attempt I was making.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I also found the original issue I was having. It turns out that the key in S3 isn’t actually created until the first apply is run. So when I was doing a terraform plan, the data lookup wasn’t finding it. I wonder how the heck it ever worked.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Hmmm, maybe now that I got past that original issue, I can retry some things.
data:image/s3,"s3://crabby-images/9e724/9e7246e580c9565322497f52f0ae7ba1f22ac888" alt="oscar avatar"
What is your goal again? And the issue
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I want to configure my s3 bucket name, key, and region in one place, that can be used both by terraform init and by terraform plan | apply | refresh | output, etc. I think I just figured it out (now that the previous issue was working on is resolved). |
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I have a file, s3.conf
, that has:
$ cat s3.conf
bucket = "foo"
key = "dns-nonprod/terraform.tfstate"
region = "us-east-1"
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I initialize like this: terraform init -backend-config=s3.conf
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
And my remote state is configured like this:
data "local_file" "s3" {
filename = "${path.module}/s3.conf"
}
terraform {
backend "s3" {
config = tomap(data.local_file.s3.content)
}
}
# Default provider works for the various pieces of the terraform initialization
provider "aws" {
region = "us-east-1"
}
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
this is really cool.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
for the longest time, interpolation wasn’t supported in this context.
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
I thought it still wasn’t
data:image/s3,"s3://crabby-images/9a0f8/9a0f8d41476ffe9065fbe0b98227d0cdcaa0cd11" alt="Erik Osterman (Cloud Posse) avatar"
@Andriy Knysh (Cloud Posse) I think we could benefit from this too.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
could be useful, agree
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
So far, it seems to be working.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
The simple solution above was just muddied by my initial error: attempting to set a data “terraform_remote_state” for an S3 key dns-nonprod/terraform.tfstate
that didn’t exist yet, because I hadn’t yet run an apply (couldn’t run an apply because init failed, because that file didn’t exist yet because I hadn’t yet run an apply, circular dependencies FTW).
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I don’t know why, but I could swear that terraform init used to create that S3 key with a minimal tfstate file. I must have been wrong. This has all been with the latest aws module and terraform 0.12.4.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Sorry for spamming the channel. I’ll exercise restraint from now on.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
i would put the backend files into a separate folder, provision it first (w/o specifying remote backend obviously b/c it does not exist yet), then add the remote backend config to the code, then terraform init
will ask you to import the old (local) backend config into the remote one
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
after that, don’t touch the tf-backend
folder
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
for all other modules, use diff folders
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"
although outdated, the doc above will give you an idea on what needs to be done to provision the remote backend without having a remote backend to provision it in the first place
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
here is the project structure that we usually use https://github.com/cloudposse/testing.cloudposse.co/tree/master/conf
Example Terraform Reference Architecture that implements a Geodesic Module for an Automated Testing Organization in AWS - cloudposse/testing.cloudposse.co
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
tfstate-backend
is in separate folder and gets provisioned separately and only once
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the code for tfstate-backend
is here https://github.com/cloudposse/terraform-root-modules/tree/master/aws/tfstate-backend
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
the script to provision the backend locally and then enable remote backend https://github.com/cloudposse/terraform-root-modules/blob/master/aws/tfstate-backend/scripts/init.sh
Example Terraform service catalog of “root module” blueprints for provisioning reference architectures - cloudposse/terraform-root-modules
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
I’ll surely study them. If I’m having trouble, I’ll bug my co-worker Jon and see if he can fill in the gaps.
data:image/s3,"s3://crabby-images/11c5e/11c5e6407728b1240bc187f94f88b6a438854d7d" alt="Todd Lyons avatar"
Thank you for all you’ve shown me.
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I’ve seen some chatter on the pre-commit-terraform working with tf 0.12, but it seems to have a problem with a simple something = var.something
declaration
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I’m on 1.19 of pre-commit-terraform so that should support it just fine
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
never used that version. why not switch to the latest 0.12?
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
pre-commit-terraform version
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
TF 0.12 p-c-t 1.19
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
hookid: terraform_docs
2019/08/30 10:51:44 At 41:5: error while trying to parse object within list: At 42:40: Unknown token: 42:40 IDENT null
^ it seems terraform-docs is not able to properly parse the code
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
Running outside of pre-commit shows:
~/Work/terraform-aws-kafka (git: feature/DEVOPS-557-kafka-module) (tf: default): terraform-docs md document .
2019/08/30 10:53:08 At 2:28: Unknown token: 2:28 IDENT var.cluster_name
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
line 2:
resource "aws_msk_cluster" "this" {
cluster_name = var.cluster_name
...
}
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
that error is when you try to parse 0.12 code with TF 0.11
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
but i’m on tf 0.12
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
: tf --version
Terraform v0.12.7
+ provider.aws v2.25.0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
maybe you have two of them installed
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
I am using tfenv
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
make sure in the Dockerfile :
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
# Install terraform 0.11 for backwards compatibility
RUN apk add terraform_0.11@cloudposse
# Install terraform 0.12
RUN apk add terraform_0.12@cloudposse terraform@cloudposse==0.12.3-r0
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
if you are using geodesic for that
data:image/s3,"s3://crabby-images/2bd80/2bd8051324042f9726131c1dca5e6d27f857be76" alt="johncblandii avatar"
nopers. all local