resource "aws_sqs_queue" "terraform_queue" { name = "terraform-example-queue" delay_seconds = 90 max_message_size = 2048 message_retention_seconds = 86400 receive_wait_time_seconds = 10 redrive_policy = "{\"deadLetterTargetArn\":\"${aws_sqs_queue.terraform_queue_deadletter.arn}\",\"maxReceiveCount\":4}" tags { Environment = "production" } }
resource "aws_sqs_queue" "terraform_queue" { name = "terraform-example-queue.fifo" fifo_queue = true content_based_deduplication = true }
resource "aws_sqs_queue" "terraform_queue" { name = "terraform-example-queue" kms_master_key_id = "alias/aws/sqs" kms_data_key_reuse_period_seconds = 300 }
The following arguments are supported:
name
- (Optional) This is the human-readable name of the queue. If omitted, Terraform will assign a random name. name_prefix
- (Optional) Creates a unique name beginning with the specified prefix. Conflicts with name
. visibility_timeout_seconds
- (Optional) The visibility timeout for the queue. An integer from 0 to 43200 (12 hours). The default for this attribute is 30. For more information about visibility timeout, see AWS docs. message_retention_seconds
- (Optional) The number of seconds Amazon SQS retains a message. Integer representing seconds, from 60 (1 minute) to 1209600 (14 days). The default for this attribute is 345600 (4 days). max_message_size
- (Optional) 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). The default for this attribute is 262144 (256 KiB). delay_seconds
- (Optional) The time in seconds that the delivery of all messages in the queue will be delayed. An integer from 0 to 900 (15 minutes). The default for this attribute is 0 seconds. receive_wait_time_seconds
- (Optional) 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). The default for this attribute is 0, meaning that the call will return immediately. policy
- (Optional) The JSON policy for the SQS queue redrive_policy
- (Optional) 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"
). fifo_queue
- (Optional) Boolean designating a FIFO queue. If not set, it defaults to false
making it standard. content_based_deduplication
- (Optional) Enables content-based deduplication for FIFO queues. For more information, see the related documentation kms_master_key_id
- (Optional) The ID of an AWS-managed customer master key (CMK) for Amazon SQS or a custom CMK. For more information, see Key Terms. kms_data_key_reuse_period_seconds
- (Optional) 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). The default is 300 (5 minutes). tags
- (Optional) A mapping of tags to assign to the queue. In addition to all arguments above, the following attributes are exported:
SQS Queues can be imported using the queue url
, e.g.
$ terraform import aws_sqs_queue.public_queue https://queue.amazonaws.com/80398EXAMPLE/MyQueue
© 2018 HashiCorpLicensed under the MPL 2.0 License.
https://www.terraform.io/docs/providers/aws/r/sqs_queue.html