#airship (2019-03)
Home of Airship ECS Modules ( https://github.com/blinkist/terraform-aws-airship-ecs-service / https://github.com/blinkist/terraform-aws-airship-ecs-cluster )
Archive: https://archive.sweetops.com/airship/
2019-03-01
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
hey guys, I’ll try to spend some more time again, started working somewhere new so last weeks were just flying and I needed to be away from my laptop in the evenings.
2019-03-03
2019-03-12
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
Hi Guys!
I was running through the airship demo, but, got stuck on some errors on the last step, creation of the fargate service itself. I checked github issues, didnt see anything similar, checked github pr’s, didnt see anything that looked the same.
in trying to debug, i bumped to the 0.8.8 tag, instead of 0.8.6 as listed in the docs
The errors are:
* module.fargate_service.module.iam.aws_iam_role_policy_attachment.ecs_tasks_execution_role: 1 error(s) occurred:
* module.fargate_service.module.iam.aws_iam_role_policy_attachment.ecs_tasks_execution_role: Resource 'aws_iam_role.ecs_task_execution_role' not found for variable 'aws_iam_role.ecs_task_execution_role.id'
* module.fargate_service.module.iam.output.ecs_task_execution_role_arn: Resource 'aws_iam_role.ecs_task_execution_role' does not have attribute 'arn' for variable 'aws_iam_role.ecs_task_execution_role.*.arn'
* module.fargate_service.module.iam.output.lambda_ecs_task_scheduler_role_arn: Resource 'aws_iam_role.lambda_ecs_task_scheduler' does not have attribute 'arn' for variable 'aws_iam_role.lambda_ecs_task_scheduler.*.arn'
* module.fargate_service.module.iam.aws_iam_role_policy.lambda_ecs_task_scheduler_policy: 1 error(s) occurred:
* module.fargate_service.module.iam.aws_iam_role_policy.lambda_ecs_task_scheduler_policy: Resource 'aws_iam_role.lambda_ecs_task_scheduler' not found for variable 'aws_iam_role.lambda_ecs_task_scheduler.name'
so it would seem like: <https://github.com/blinkist/terraform-aws-airship-ecs-service/blob/master/modules/iam/main.tf#L22>
isnt getting created. This is weird, because I set create=true
as well as fargate_enabled=true
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
i was curious if there was something simple that i missed, or a pointer of where to look next
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Hi @jaustinpage do you have any other errors maybe regarding the creation of IAM resources ? Also, does your user for terraform has AdministratorAccess ?
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
@maarten: no, no other errors. lemme make 100% certain i have admin…
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
yep, the assumerole i am using has AdministratorAccess
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ok, so that’s all good
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
im surprised that there isnt a resource creation error, it seems like it never got to the point where it could try to create resources
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
can you run terraform -v in your root module ?
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
one other potential red herring: when i tried to create the ecs cluster, i did get an error, but then manually applied https://github.com/blinkist/terraform-aws-airship-ecs-cluster/pull/10 to fix
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
terraform -v
Terraform v0.11.11
+ provider.aws v2.0.0
+ provider.null v2.1.0
+ provider.template v2.1.0
Your version of Terraform is out of date! The latest version
is 0.11.12. You can update by downloading from www.terraform.io/downloads.html
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
ill update tf
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ok, let me go through the same loop as you, and see if the new aws provider breaks something
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
terraform -v
Terraform v0.11.13
+ provider.aws v2.0.0
+ provider.null v2.1.0
+ provider.template v2.1.0
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
updated terraform makes no difference, lemme double check my providers…
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
i was 1 version back on the aws provider, lets see if that fixes
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
ahh, gotta manually patch for the owners attribute again…
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
no wait
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
use 0.5.1
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
module "ecs" {
source = "blinkist/airship-ecs-cluster/aws"
version = "0.5.1"
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
ahhh! nice
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
much appreciated!
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ok, now I’m running ecs service adding
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
yep, no luck with provider aws v2.1.0
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
@maarten: thank you so much for all the help, by the way, i really appreciate it
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ok, i get some other errors regarding policies
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
a different set of errors?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
* module.fargate_service.module.iam.aws_iam_role_policy.lambda_lookup_policy: 1 error(s) occurred:
* aws_iam_role_policy.lambda_lookup_policy: Error putting IAM role policy terraform-20190312184616302000000001: MalformedPolicyDocument: The policy failed legacy parsing
status code: 400, request id: 1e46ae1b-44f7-11e9-ac46-ddd75d8a23d7
* module.fargate_service.module.iam.aws_iam_role_policy.lambda_ecs_task_scheduler_policy: 1 error(s) occurred:
* aws_iam_role_policy.lambda_ecs_task_scheduler_policy: Error putting IAM role policy terraform-20190312184616313900000002: MalformedPolicyDocument: The policy failed legacy parsing
status code: 400, request id: 1e461169-44f7-11e9-8ea3-e7746315f9c9
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
hmmm, that would mean that it made it further than it did for me i think…
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
i dont know if this helps, but, i ran tf on 0.8.6, then 0.8.8, im not sure if that caused some of the resources to make it further or not…
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
it should just work, so let me fix this, not sure what’s going on
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
ok, let me know what I can do to assist
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-cluster avatar"
0.5.1: Added owners attribute to ecs_ami (#10) added owners attribute to ecs_ami owner: self -> amazon
Terraform module which creates an ECS Cluster with integrated instance scaling and EFS mounting capability - blinkist/terraform-aws-airship-ecs-cluster
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@jaustinpage what do you have at ` region = `
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
region = "${data.aws_region.current.name}"'
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
Line 0: data "aws_region" "current" {}
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ok, that’s good
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
the reason for that is im creating the same resources in 2 regions. technically i am calling the airship module from a homespun “region” module, so that i can make all the regions the same.
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
and, i may have doctored the above logs to hide this fact…
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
we all have our secrets
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
so are you using 2 different aws providers atm ?
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
3, but only 2 are having airship called at the moment
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and you pass the provider block to both modules
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
the 3rd one is handling some aws credential stuff that is happening behind the scenes
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
i pass the provider block to the homespun region module
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
then use default inheritance from there
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ok, but for me to understand
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
you have one root module, in which you create 3 different aws providers
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
then you create 2 ecs clusters
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
let me put together some excerpts
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
you pass both ecs clusters the provider block like:
module “example” { source = “./example” providers = { aws = “aws.usw2” } }
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and pass the same provider block to the relevant ecs service modules
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
and then the “modules/region” module looks just like a normal demo.
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
inside the modules/region module, because it was handed a single aws provider, we let the default provider inheritance in terraform do the rest of the work
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
that should cascade down
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
But i’m not interpolating region names in my resources. Could you interpolate the region name or a short version of it in the name of the ecs service ?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and test
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
sure thing, i would have hoped a name conflict to produce a better error message (which would be a tf/provider bug), but ill give it a shot
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
` name = “${var.name}-${terraform.workspace}-${data.aws_region.current.name}”`
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
how long are the names of your workspaces ?
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
‘lower’ and ‘production’
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
maybe you can substr 0,3 them for now, the ecs cluster name will also be interpolated, and that can result in some issues unfortunately
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
lets first see if we can get it to work with short names
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
hmm, i am getting the 64char limit now
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
ill find another way to unique them
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
k
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
i ran into some other bugs, itl take a sec for me to fix them.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
sure
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
yeah, got some name collisions with the change in name above, its just gonna take a sec to remove the existing resource and re-add to make sure that all the resources get recreated
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
ok, back to the initial state
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
of errors that were listed above
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Is there a way for you to simplify the setup step-by-step to be able to start ruling out stuff.
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
i take it you are having difficulty reproducing?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
the errors I had earlier were something else.
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
yep, ill simplify.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
and was a human error on my side, by bluntly copying the ecs_service block without modifying the region
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
messing with the name of both the ecs and fargate_service modules appears to have moved this on to a new error. thanks so much for your help @maarten, i think that was it
data:image/s3,"s3://crabby-images/d9a67/d9a67ded64d39060556f0d2d71026a1723c72cb1" alt="jaustinpage avatar"
must have been some sort of weird naming collisions just not throwing the errors i would have expected
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
That happens sometimes, the real errors are hidden, takes some effort to figure those out.
2019-03-13
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Those are the worst.
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
It can take ages to debug resources that have maps or lists that have one wrong or missing value in them.
data:image/s3,"s3://crabby-images/9d73b/9d73b559487f408b9e25c3ade792e1c2c102ba51" alt="jamie avatar"
Because the terraform parser that handles it says that the error is in a count, or in another component.
2019-03-14
2019-03-18
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-service avatar"
0.9.0: Load balancer map removal (#47) Added an example of create = false Load balancer map removal
Terraform module which creates an ECS Service, IAM roles, Scaling, ALB listener rules.. Fargate & AWSVPC compatible - blinkist/terraform-aws-airship-ecs-service
2019-03-21
data:image/s3,"s3://crabby-images/64c10/64c102244b1ba11a01ca1ca16fb08102f89b9e81" alt="johnbeans avatar"
when i run terraform with the airship module it seems to want to try to overwrite the task definition of my service… is there anything i can do to make it skip trying to do that?
~ module.fargate_service.module.ecs_service.aws_ecs_service.app_with_lb_awsvpc
task_definition: "internal-tools-admin-api:15" => "internal-tools-admin-api:12"
2019-03-22
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
John, can you (privately) paste me your ecs module definition, and disclose a bit more of your plan. Normally the module takes the current taskdefinition unless it’s changed. If it is changed it would create a new task definition with the image of the live definition.
2019-03-25
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-service avatar"
0.9.1 Moving getting_started into this repository as well
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/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
hm
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-service avatar"
Registry won't publish currently. Attribute redefined: The argument "filter" was already set at ./examples/with_nlb/main.tf:72,3-9. Each argument may be set only once. (in main.tf on …
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-service avatar"
Terraform module which creates an ECS Service, IAM roles, Scaling, ALB listener rules.. Fargate & AWSVPC compatible - blinkist/terraform-aws-airship-ecs-service
What Rename faulty container_command to command Why Breaks the module.
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-service avatar"
0.9.2: Travis cli install + proper config build trigger (#55) Travis install + proper config
Install travis gem only within the condition branch=master
Terraform module which creates an ECS Service, IAM roles, Scaling, ALB listener rules.. Fargate & AWSVPC compatible - blinkist/terraform-aws-airship-ecs-service