AWS Service Scheduler¶
The AWS Service Scheduler is an open-source project developed to help scheduling AWS resources. It is based on AWS Step Functions and Lambda, and can be deployed in any AWS account.
It's main feature is to start and stop resources on a schedule, mainly for finops purposes but can also be used for other use cases.
The key features are:
- Easy to use: The only thing to do is to add tags to your resources, the scheduler will do the rest.
- Easy to deploy: Deploy in minutes, simply add the module to your Terraform code.
- Customizable: You want custom tags ? No problem, you can customize the tags used by the scheduler.
- Secure: The scheduler will only be able to start and stop resources identified by the tags you specified.
- Cost-effective: The scheduler is serverless, based on Step Functions and Lambda.
- Open-source: The code is available on GitHub, feel free to contribute !
Usage¶
module "service_scheduler" {
source = "phergoualch/service-scheduler/aws"
version = ">= 2.0.0"
enabled_services = ["ec2", "asg", "ecs", "rds", "documentdb", "lambda", "apprunner", "aurora", "elasticache", "cloudwatch"] #(1)!
default_timezone = "Europe/Paris" #(2)!
app_name = "service-scheduler" #(3)!
execution_interval = 6 #(4)!
}
- List of services to enable in the scheduler
- Default timezone used to calculate the start and stop times
- Name of the application, used to generate the resources names
- Interval between each execution of the state machine