An auto-scaling solution for Amazon DocumentDB.
This project is an AWS Lambda written in Python and deployed with Terraform that easily implements auto-scaling functionality for Amazon DocumentDB.
Amazon DocumentDB (with MongoDB compatibility) supports up to 15 read replicas, but by default AWS does not provide an easy way to set up an auto-scaling policy for them.
Follow below how the system works:
Resources created by Terraform:
- CloudWatch alarm ─ will watch a CloudWatch metric from the Document Database cluster (e.g.
CPUUtilization
). - Simple Notification Service (SNS) ─ will be triggered by CloudWatch when any metrics are matched.
- AWS Lambda ─ will be triggered by the SNS and will be responsible for adding or removing read replicas in the Document Database cluster.
You can deploy the function with Terraform using the following syntax:
module "docdb-autoscaling" {
source = "github.com/OtavioBernardes/terraform-aws-docdb-autoscaling"
cluster_identifier = aws_docdb_cluster.docdb.id
name = "docdb-mydbname-autoscaling"
min_capacity = 1
max_capacity = 3
scaledown_schedule = "rate(30 minutes)"
scaling_policy = {
metric_name = "CPUUtilization"
target = 60
statistic = "Average"
cooldown = 300
scaledown_target = 50
period = 3600
}
}
To create the resources:
terraform init
terraform plan
terraform apply
To destroy:
terraform destroy
Variable | Description | Type | Default value |
---|---|---|---|
cluster_identifier |
DocumentDB cluster identifier. | string |
n/a |
name |
Resources name. | string |
"docdb-autoscaling" |
min_capacity |
The minimum capacity. | number |
0 |
max_capacity |
The maximum capacity. | number |
15 |
scaledown_schedule |
The verification period for scaledown | string |
"rate(1 hour)" |
scaling_policy |
The auto-scaling policy. | see here | see here |
Type:
type = object({
metric_name = string
target = number
scaledown_target = number
statistic = string
cooldown = number
period = number
})
Default value:
scaling_policy = {
metric_name = "CPUUtilization"
target = 60
statistic = "Average"
cooldown = 300
scaledown_target = 50
period = 3600
}
Options:
metric_name
─ Amazon DocumentDB metric name (see the list).target
─ The value against which the specified statistic is compared.statistic
─ The statistic to apply to the alarm's associated metric (supported values:SampleCount
,Average
,Sum
,Minimum
,Maximum
).cooldown
─ The cooldown period between scaling actions.
n/a
MIT