#airship (2019-04)
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-04-03
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
Hi guys
I have a problem with service shown in the snippet. I deployed the service successfully earlier, but ran into problems after destroying my environment over night and reapplying it today.
After first terraform apply
I get the following error:
Error: Error applying plan:
1 error(s) occurred:
* module.linkmobility.module.live_task_lookup.data.aws_lambda_invocation.lambda_lookup: data.aws_lambda_invocation.lambda_lookup: AccessDeniedException: The role defined for the function cannot be assumed by Lambda.
status code: 403, request id: 280f95ac-e6a2-4738-935e-5b9c013e9ceb
It seems related to the timing of resource creation, but when I rerun the apply I get a new error every time I rerun:
Error: Error applying plan:
1 error(s) occurred:
* module.linkmobility.module.ecs_service.aws_ecs_service.app_with_lb: 1 error(s) occurred:
* aws_ecs_service.app_with_lb: ClientException: TaskDefinition is inactive
status code: 400, request id: ab7ef1d7-5601-11e9-8828-d365d379c104 "linkmobility"
I think it’s because the old task defintion never gets deleted, just deactivated, and that trips up the new creation.
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
@maarten & @Maciek Strömich: Any suggestions?
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Will try to get back to you this evening, have to work on work stuff now.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
“* module.linkmobility.module.live_task_lookup.data.aws_lambda_invocation.lambda_lookup: data.aws_lambda_invocation.lambda_lookup: AccessDeniedException: The role defined for the function cannot be assumed by Lambda.”
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
interesting, let me get back to you later
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
While I’ve been banging on the module for the last few days, I’ve seen a couple of similar situations, where something is a dependency, but isn’t available quickly enough. Re-running fixes most of them, but I’ve hit an impasse here.
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
The thing is that deleting a taskdef doesn’t remove it, merely inactivates it. when you deactivate the last taskdef version, the entire taskdef becomes inactive, but it doesn’t disappear.
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
looking at the docs i think it never disappears
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
what you can always do for now
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
is to add an env var
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I’ve ran into issues where I’ve created an ECS service with the module, after that deleted it again, but the old task definitions are more or less kept in AWS. This creates a weird irregularity
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
I’m really looking fwd to implementing this the moment tf supports it: https://aws.amazon.com/about-aws/whats-new/2019/03/aws-fargate-and-amazon-ecs-support-external-deployment-controlle/
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
i tried to force a new taskdef with force_bootstrap_container_image
but I’ll try the env var now
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
so for now
container_envvars {
FIX = "1"
}
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
well, you could support it now with a lambda, like you handle the live task check
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
• module.linkmobility.module.live_task_lookup.data.aws_lambda_invocation.lambda_lookup: data.aws_lambda_invocation.lambda_lookup: AccessDeniedException: The role defined for the function cannot be assumed by Lambda.
this however doesn’t explain the task definition issue you have
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
Thanks!
container_envvars = {
stamp = 1554291327
}
… worked like a charm.
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
like i wrote, the first error disappears when i rerun. i think its timing related.
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
like maybe it takes a second for a new policy to propagate, and terraform is already trying to use it
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
hm shouldn’t be!
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
btw, i also submitted a PR to fix a bug in the lambdas. there was some python cut and paste in the error reporting that made all errors have the message “NaN”
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
i assume it’s python, since it looked like python string building
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
anywho, thanks for the workaround
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
ah nice, thanks.
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
np, any time.
2019-04-10
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
@maarten how do you feel about https://github.com/blinkist/terraform-aws-airship-ecs-service/pull/59 ?
Added stack to custom error. Without it, error origin is lost. Changed Python string building to JS concatenation. String modulo string gives a NaN result every time. Respect the health check grace…
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
Looks good, very clean, thanks!
Added stack to custom error. Without it, error origin is lost. Changed Python string building to JS concatenation. String modulo string gives a NaN result every time. Respect the health check grace…
data:image/s3,"s3://crabby-images/fe27f/fe27f3a1b4bf8e54e2d3100cd1bcb467ca04a5b9" alt="Release notes from terraform-aws-airship-ecs-service avatar"
0.9.3: Minor bugfixing (#59) Fixed bug in custom exception and error reporting
Added stack to custom error. Without it, error origin is lost.
Changed Python string building to JS concatenation. string modulo string gives a NaN result every time.
Cleanup.
Respect the health check grace period variable
Statement actions MUST be lists in Terraform.
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/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
Is there a way to make environment vars for containers “valueFrom” instead of “value”?
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
~NVM. I’ll add it and submit a PR.~https://github.com/blinkist/terraform-aws-airship-ecs-service/pull/61>
2019-04-25
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
Hi @maarten. I got around to look at the drift detection you requested in the PR above. Looking at the code, I’m uncertain about how to proceed. There doesn’t seem to be any special precautions for normal environment variables. What am I missing?
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
Looking at the lookup lambda, i can see where you get the env vars, but it doesn’t look like javascript’s describetaskdefintion returns the secrets as part of the container …
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
I use ecs-deploy
(https://github.com/silinternational/ecs-deploy) on my CI server to update the container image when the code changes.
The script fetches the running taskdef and replace the image before uploading a new task def.
However, if I run terraform to update something else, it detects a “change” and wants to downgrade to the last task defintion created with Terraform.
I’m not sure if this is related to secrets, or ecs-deploy “scrubbing off” something that Airship uses to detect the newest image.
Any ideas?
Simple shell script for initiating blue-green deployments on Amazon EC2 Container Service (ECS) - silinternational/ecs-deploy
2019-04-26
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
hi @Mads Hvelplund so as we cannot retrieve that from the datasource we need to do something else. You can store a hash of the combined secrets-names in a label, and compare the label for drift detection.
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
when your buildserver builds a new docker image, how do you deploy it? by running terraform, or using aws cli/api?
2019-04-29
data:image/s3,"s3://crabby-images/d5031/d5031300af44c892cac3b8f038d2084cc70b2b00" alt="maarten avatar"
@Mads Hvelplund using ecs-deploy as well, and the drift detection always made sure that ecs-deploy could do its work
2019-04-30
data:image/s3,"s3://crabby-images/87a1c/87a1cab73667b0b17ec520b7c927060c7f77e7e7" alt="Mads Hvelplund avatar"
FYI: ecs-deploy
doesn’t support secrets unless you run with the changes from https://github.com/silinternational/ecs-deploy/pull/179
.. or rather, it only supports Fargate containers that use secrets, without the fix
If "executionRoleArn" is specified for Task, ecs-deploy will result in an error and a filter will be added because it failed. An error occurred (ClientException) when calling the Register…