Terraform module which creates AWS MemoryDB resources.
See examples
directory for working examples to reference:
module "memory_db" {
source = "terraform-aws-modules/memory-db/aws"
# Cluster
name = "example"
description = "Example MemoryDB cluster"
engine_version = "6.2"
auto_minor_version_upgrade = true
node_type = "db.t4g.small"
num_shards = 2
num_replicas_per_shard = 2
tls_enabled = true
security_group_ids = ["sg-12345678"]
maintenance_window = "sun:23:00-mon:01:30"
sns_topic_arn = "arn:aws:sns:us-east-1:012345678910:example-topic"
snapshot_retention_limit = 7
snapshot_window = "05:00-09:00"
# Users
users = {
admin = {
user_name = "admin-user"
access_string = "on ~* &* +@all"
passwords = ["YouShouldPickAStrongSecurePassword987!"]
tags = { User = "admin" }
}
readonly = {
user_name = "readonly-user"
access_string = "on ~* &* -@all +@read"
passwords = ["YouShouldPickAStrongSecurePassword123!"]
tags = { User = "readonly" }
}
}
# ACL
acl_name = "example-acl"
acl_tags = { Acl = "custom" }
# Parameter group
parameter_group_name = "example-param-group"
parameter_group_description = "Example MemoryDB parameter group"
parameter_group_family = "memorydb_redis6"
parameter_group_parameters = [
{
name = "activedefrag"
value = "yes"
}
]
parameter_group_tags = {
ParameterGroup = "custom"
}
# Subnet group
subnet_group_name = "example-subnet-group"
subnet_group_description = "Example MemoryDB subnet group"
subnet_ids = ["subnet-1fe3d837", "subnet-129d66ab", "subnet-1211eef5"]
subnet_group_tags = {
SubnetGroup = "custom"
}
tags = {
Terraform = "true"
Environment = "dev"
}
}
The following values are provided to toggle on/off creation of the associated resources as desired:
module "memory_db" {
source = "terraform-aws-modules/memory-db/aws"
# Disable creation of cluster and all resources
create = false
# Disable creation of users
create_users = false
# Disable creation of ACL - an ACL will need to be provided
create_acl = false
acl_name = "existing_acl"
# Disable creation of parameter group - a parameter group will need to be provided
create_parameter_group = false
parameter_group_name = "existing_parameter_group"
# Disable creation of subnet group - a subnet group will need to be provided
create_subnet_group = false
subnet_group_name = "existing_subnet_group"
# ... omitted
}
Examples codified under the examples
are intended to give users references for how to use the module(s) as well as testing/validating changes to the source code of the module. If contributing to the project, please be sure to make any appropriate updates to the relevant examples to allow maintainers to test your changes and to keep the examples up to date for users. Thank you!
Name | Version |
---|---|
terraform | >= 1.0 |
aws | >= 5.82 |
Name | Version |
---|---|
aws | >= 5.82 |
No modules.
Name | Type |
---|---|
aws_memorydb_acl.this | resource |
aws_memorydb_cluster.this | resource |
aws_memorydb_parameter_group.this | resource |
aws_memorydb_subnet_group.this | resource |
aws_memorydb_user.this | resource |
Name | Description | Type | Default | Required |
---|---|---|---|---|
acl_name | Name of ACL to be created if create_acl is true , otherwise its the name of an existing ACL to use if create_acl is false |
string |
null |
no |
acl_tags | Additional tags for the ACL created | map(string) |
{} |
no |
acl_use_name_prefix | Determines whether acl_name is used as a prefix |
bool |
false |
no |
acl_user_names | List of externally created user names to associate with the ACL | list(string) |
[] |
no |
auto_minor_version_upgrade | When set to true , the cluster will automatically receive minor engine version upgrades after launch. Defaults to true |
bool |
null |
no |
create | Determines whether resources will be created - affects all resources | bool |
true |
no |
create_acl | Determines whether to create ACL specified | bool |
true |
no |
create_parameter_group | Determines whether to create parameter group specified | bool |
true |
no |
create_subnet_group | Determines whether to create subnet group specified | bool |
true |
no |
create_users | Determines whether to create users specified | bool |
true |
no |
data_tiering | Must be set to true when using a data tiering node type |
bool |
null |
no |
description | Description for the cluster. Defaults to Managed by Terraform |
string |
null |
no |
engine | The engine that will run on your nodes. Supported values are redis and valkey | string |
null |
no |
engine_version | Version number of the engine to be used for the cluster. Downgrades are not supported | string |
null |
no |
final_snapshot_name | Name of the final cluster snapshot to be created when this resource is deleted. If omitted, no final snapshot will be made | string |
null |
no |
kms_key_arn | ARN of the KMS key used to encrypt the cluster at rest | string |
null |
no |
maintenance_window | Specifies the weekly time range during which maintenance on the cluster is performed. It is specified as a range in the format ddd:hh24:mi-ddd:hh24:mi |
string |
null |
no |
multi_region_cluster_name | The multi region cluster identifier if part of a multi region cluster | string |
null |
no |
name | Cluster name - also default name used on all resources if more specific resource names are not provided | string |
"" |
no |
node_type | The compute and memory capacity of the nodes in the cluster. See AWS documentation on supported node types as well as vertical scaling | string |
null |
no |
num_replicas_per_shard | The number of replicas to apply to each shard, up to a maximum of 5. Defaults to 1 (i.e. 2 nodes per shard) |
number |
null |
no |
num_shards | The number of shards in the cluster. Defaults to 1 |
number |
null |
no |
parameter_group_description | Description for the parameter group. Defaults to Managed by Terraform |
string |
null |
no |
parameter_group_family | The engine version that the parameter group can be used with | string |
null |
no |
parameter_group_name | Name of parameter group to be created if create_parameter_group is true , otherwise its the name of an existing parameter group to use if create_parameter_group is false |
string |
null |
no |
parameter_group_parameters | A list of parameter maps to apply | list(map(string)) |
[] |
no |
parameter_group_tags | Additional tags for the parameter group created | map(string) |
{} |
no |
parameter_group_use_name_prefix | Determines whether parameter_group_name is used as a prefix |
bool |
false |
no |
port | The port number on which each of the nodes accepts connections. Defaults to 6379 |
number |
null |
no |
security_group_ids | Set of VPC Security Group ID-s to associate with this cluster | list(string) |
null |
no |
snapshot_arns | List of ARN-s that uniquely identify RDB snapshot files stored in S3. The snapshot files will be used to populate the new cluster | list(string) |
null |
no |
snapshot_name | The name of a snapshot from which to restore data into the new cluster | string |
null |
no |
snapshot_retention_limit | The number of days for which MemoryDB retains automatic snapshots before deleting them. When set to 0 , automatic backups are disabled. Defaults to 0 |
number |
null |
no |
snapshot_window | The daily time range (in UTC) during which MemoryDB begins taking a daily snapshot of your shard. Example: 05:00-09:00 |
string |
null |
no |
sns_topic_arn | ARN of the SNS topic to which cluster notifications are sent | string |
null |
no |
subnet_group_description | Description for the subnet group. Defaults to Managed by Terraform |
string |
null |
no |
subnet_group_name | Name of subnet group to be created if create_subnet_group is true , otherwise its the name of an existing subnet group to use if create_subnet_group is false |
string |
null |
no |
subnet_group_tags | Additional tags for the subnet group created | map(string) |
{} |
no |
subnet_group_use_name_prefix | Determines whether subnet_group_name is used as a prefix |
bool |
false |
no |
subnet_ids | Set of VPC Subnet ID-s for the subnet group. At least one subnet must be provided | list(string) |
[] |
no |
tags | A map of tags to use on all resources | map(string) |
{} |
no |
tls_enabled | A flag to enable in-transit encryption on the cluster. When set to false , the acl_name must be open-access . Defaults to true |
bool |
null |
no |
use_name_prefix | Determines whether name is used as a prefix for the cluster |
bool |
false |
no |
users | A map of user definitions (maps) to be created | any |
{} |
no |
Name | Description |
---|---|
acl_arn | The ARN of the ACL |
acl_id | Name of the ACL |
acl_minimum_engine_version | The minimum engine version supported by the ACL |
cluster_arn | The ARN of the cluster |
cluster_endpoint_address | DNS hostname of the cluster configuration endpoint |
cluster_endpoint_port | Port number that the cluster configuration endpoint is listening on |
cluster_engine_patch_version | Patch version number of the Redis engine used by the cluster |
cluster_id | Cluster name |
cluster_shards | Set of shards in this cluster |
parameter_group_arn | The ARN of the parameter group |
parameter_group_id | Name of the parameter group |
subnet_group_arn | ARN of the subnet group |
subnet_group_id | Name of the subnet group |
subnet_group_vpc_id | The VPC in which the subnet group exists |
users | Map of attributes for the users created |
Apache-2.0 Licensed. See LICENSE.