#terraform-0_12 (2019-12)
Discuss upgrading to terraform 0.12
Archive: https://archive.sweetops.com/terraform-0_12/
2019-12-10
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
Hello, I am trying to install nginx-ingress helm chart to a fresh EKS cluster using TF, but the apply times out everytime with the error Error: timeout while waiting for state to become 'Running' (last state: 'Pending', timeout: 5m0s)
. I have tried increasing the timeout to 3000
but seems to have no effect.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
You don’t have nodes in the cluster
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
kubectl get nodes
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Try that ^
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
thanks @Andriy Knysh (Cloud Posse) .. tiller wasn’t deployed to the cluster..should have checked that..my bad
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
In case of issues, you can also try:
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
kubectl cluster-info dump
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
Kubectl describe pod xxxxxx
data:image/s3,"s3://crabby-images/44902/449029945fc1a4b20fc4380407df7a1de709e0f8" alt="curious deviant avatar"
sure..thank you
2019-12-12
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
Does anyone know if it’s possible to use for_each or dynamic values for a provider block? If not, do you have a way to make the same resource across many accounts?
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
dynamic blocks are supported inside resource, data, provider, and provisioner blocks
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
The Terraform language allows the use of expressions to access data exported by resources and to transform and combine that data to produce other values.
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
we use assume_role
to re-use code for diff accounts https://www.terraform.io/docs/providers/aws/index.html#assume-role
The Amazon Web Services (AWS) provider is used to interact with the many resources supported by AWS. The provider needs to be configured with the proper credentials before it can be used.
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
yeah that’s what we have for our providers… in this case we want to make an AWS Config rule across all of our accounts so we need to make the same resource with each provider
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
it seems like we need to either have X number of modules with a different provider or one module with X number of resources that reference a list of providers
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
was wondering if there is a way to clean this up using a loop in TF 12
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
you can have one module that accepts a list of account IDs (or a map, if you want to use for_each)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in it, you use provider block with count or for_each (for which you need to provide a map)
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
in each resource in the module, you use count (or for_each) and specify the provider by index
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
ah okay… let me give that a try
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
The user that executes the code must have permissions to assume all those roles that are generated in the provider assume_role block
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
Seems like they haven’t implemented this functionality yet. Using this config:
provider "aws" {
for_each = var.aws_account_ids
dynamic "assume_role" {
for_each = var.aws_account_ids
content {
role_arn = "arn:aws:iam::${each.value}:role/super-user"
session_name = "terraform"
}
}
profile = "sts"
region = "us-west-2"
version = "2.41.0"
}
Returns :
Error: Reserved argument name in provider block
on ../../../modules/site/all-accounts-aws-config-rule/v3/main.tf line 14, in provider "aws":
14: for_each = var.aws_account_ids
The provider argument name "for_each" is reserved for use by Terraform in a
future version.
I also tried the for_each or the provider block as well with the same result
data:image/s3,"s3://crabby-images/3a2ce/3a2ce4c6bc76226bf51216a9ec67ba1e2791323a" alt="Andriy Knysh (Cloud Posse) avatar"
what about count
in provider block?
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
Same
Error: Reserved argument name in provider block
on ../../../modules/site/all-accounts-aws-config-rule/v3/main.tf line 14, in provider "aws":
14: count = length(var.aws_account_ids)
The provider argument name "count" is reserved for use by Terraform in a
future version.
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
So realized there was a mistake in my attempt with for_each, I needed to delete the resource level for_each statement. However, this still doesn’t seem possible because you can’t dynamically specify the provider in a resource or the alias in a provider
2019-12-16
data:image/s3,"s3://crabby-images/c61a1/c61a1f45be7e076ee14a36e6f8c85dc254ae9728" alt="Gabe avatar"
also using terraform 0.12.18 which is the newest