Terraform module which creates SQS resources on AWS.
These types of resources are supported:
- SQS queue with optional server-side encryption using KMS
Terraform 0.12. Pin module version to ~> v2.0
. Submit pull-requests to master
branch.
Terraform 0.11. Pin module version to ~> v1.0
. Submit pull-requests to terraform011
branch.
module "user_queue" {
source = "terraform-aws-modules/sqs/aws"
version = "~> 2.0"
name = "user"
tags = {
Service = "user"
Environment = "dev"
}
}
Sometimes you need to have a way to create SQS queue conditionally but Terraform does not allow to use count
inside module
block, so the solution is to specify argument create
.
# This SQS queue will not be created
module "user_queue" {
source = "terraform-aws-modules/sqs/aws"
version = "~> 2.0"
create = false
# ... omitted
}
Name | Version |
---|---|
terraform | >= 0.12.7 |
aws | >= 2.30 |
Name | Version |
---|---|
aws | >= 2.30 |
Name | Description | Type | Default | Required |
---|---|---|---|---|
content_based_deduplication | Enables content-based deduplication for FIFO queues | bool |
false |
no |
create | Whether to create SQS queue | bool |
true |
no |
delay_seconds | The time in seconds that the delivery of all messages in the queue will be delayed. An integer from 0 to 900 (15 minutes) | number |
0 |
no |
fifo_queue | Boolean designating a FIFO queue | bool |
false |
no |
kms_data_key_reuse_period_seconds | The length of time, in seconds, for which Amazon SQS can reuse a data key to encrypt or decrypt messages before calling AWS KMS again. An integer representing seconds, between 60 seconds (1 minute) and 86,400 seconds (24 hours) | number |
300 |
no |
kms_master_key_id | The ID of an AWS-managed customer master key (CMK) for Amazon SQS or a custom CMK | string |
null |
no |
max_message_size | The limit of how many bytes a message can contain before Amazon SQS rejects it. An integer from 1024 bytes (1 KiB) up to 262144 bytes (256 KiB) | number |
262144 |
no |
message_retention_seconds | The number of seconds Amazon SQS retains a message. Integer representing seconds, from 60 (1 minute) to 1209600 (14 days) | number |
345600 |
no |
name | This is the human-readable name of the queue. If omitted, Terraform will assign a random name. | string |
null |
no |
name_prefix | A unique name beginning with the specified prefix. | string |
null |
no |
policy | The JSON policy for the SQS queue | string |
"" |
no |
receive_wait_time_seconds | The time for which a ReceiveMessage call will wait for a message to arrive (long polling) before returning. An integer from 0 to 20 (seconds) | number |
0 |
no |
redrive_policy | The JSON policy to set up the Dead Letter Queue, see AWS docs. Note: when specifying maxReceiveCount, you must specify it as an integer (5), and not a string ("5") | string |
"" |
no |
tags | A mapping of tags to assign to all resources | map(string) |
{} |
no |
visibility_timeout_seconds | The visibility timeout for the queue. An integer from 0 to 43200 (12 hours) | number |
30 |
no |
Name | Description |
---|---|
this_sqs_queue_arn | The ARN of the SQS queue |
this_sqs_queue_id | The URL for the created Amazon SQS queue |
this_sqs_queue_name | The name of the SQS queue |
Module managed by Anton Babenko.
Apache 2 Licensed. See LICENSE for full details.