GitXplorerGitXplorer
m

ecs-host-service-scale

public
34 stars
30 forks
1 issues

Commits

List of commits on branch master.
Unverified
ea158e1741fda417678f41a61c73dd4b46569bda

Create LICENSE

mmiketheman committed 7 years ago
Verified
06b9051a6b3d3e51e650e1c1833055bd10f09e0a

:arrow_up: Update dependencies, include pytest-socket

mmiketheman committed 8 years ago
Verified
29ab3458b3efbdd273077ab67565481f538cfa71

:books: README update

mmiketheman committed 8 years ago
Verified
16a6cc2b522cb90df62c3fa37189da9f1a4a01a0

:shirt: Use function from code in tests over new session

mmiketheman committed 8 years ago
Verified
6f0619599fbf0a0629c2b058f16800697af867d7

:shirt: Remove print statements from test assertions

mmiketheman committed 8 years ago
Verified
2d6d57d472db0a83b0426e6ffe94674239859e1c

:shirt: Use more readable logical comparison

mmiketheman committed 8 years ago

README

The README file for this repository.

ecs-host-service-scale

A Lambda function to ensure an ECS Service is set to the correct Desired Count for a One-Task-Per-Host placement value for any cluster that runs the Service.

Requirements

  • boto3 (included in AWS Lambda functions, no need for packaged deployment)
  • ECS_SERVICE_ARN environment variable
  • IAM Role/Policy access setup

Flow

UML Sequence Flow

Deployment

The function is meant to be deployed as a non-VPC Lambda function. It will probably work in a VPC environment, given an Internet Gateway and proper permissions, but it simply does not need access to any in-VPC resources, only AWS API calls.

  • IAM Policy & IAM Role allowing: ecs:Describe* and ecs:UpdateService
  • CloudWatch Event Rule for: {"source": ["aws.ecs"], "detail-type": ["ECS Container Instance State Change"]}
  • Code from lambda_function.py
  • The ECS Service ARN environment variable

Testing

  • Install all requirements via pip install -r requirements.txt
  • Execute tests vis pytest

See py.test docs and botocore Stubber reference for more.

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Test your changes with pytest --cov - the tests currently cover the code 100% - don't lower that number!
  4. Commit your changes (git commit -am 'Add some feature')
  5. Push to the branch (git push origin my-new-feature)
  6. Create a new Pull Request

Author

Mike Fiedler (miketheman@gmail.com)