Skip to content

Commit 8410ca1

Browse files
committed
CCM-7939: enable high throughput fifo queues
1 parent 6445f48 commit 8410ca1

3 files changed

Lines changed: 25 additions & 0 deletions

File tree

infrastructure/modules/sqs/README.md

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,10 +16,12 @@
1616
| <a name="input_component"></a> [component](#input\_component) | The name of the tfscaffold component | `string` | n/a | yes |
1717
| <a name="input_content_based_deduplication"></a> [content\_based\_deduplication](#input\_content\_based\_deduplication) | Enables content-based deduplication for FIFO queues | `bool` | `false` | no |
1818
| <a name="input_create_dlq"></a> [create\_dlq](#input\_create\_dlq) | Create a DLQ | `bool` | `false` | no |
19+
| <a name="input_deduplication_scope"></a> [deduplication\_scope](#input\_deduplication\_scope) | For FIFO queues, specifies whether message deduplication occurs at the message group or queue level. Valid values are messageGroup and queue (default). | `string` | `"queue"` | no |
1920
| <a name="input_default_tags"></a> [default\_tags](#input\_default\_tags) | A map of default tags to apply to all taggable resources within the component | `map(string)` | `{}` | no |
2021
| <a name="input_delay_seconds"></a> [delay\_seconds](#input\_delay\_seconds) | 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 |
2122
| <a name="input_environment"></a> [environment](#input\_environment) | The name of the tfscaffold environment | `string` | n/a | yes |
2223
| <a name="input_fifo_queue"></a> [fifo\_queue](#input\_fifo\_queue) | Boolean designating a FIFO queue | `bool` | `false` | no |
24+
| <a name="input_fifo_throughput_limit"></a> [fifo\_throughput\_limit](#input\_fifo\_throughput\_limit) | For FIFO queues, specifies whether the FIFO queue throughput quota applies to the entire queue or per message group. Valid values are perQueue (default) and perMessageGroupId. | `string` | `"perQueue"` | no |
2325
| <a name="input_kms_data_key_reuse_period_seconds"></a> [kms\_data\_key\_reuse\_period\_seconds](#input\_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 |
2426
| <a name="input_max_message_size"></a> [max\_message\_size](#input\_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 |
2527
| <a name="input_message_retention_seconds"></a> [message\_retention\_seconds](#input\_message\_retention\_seconds) | The number of seconds Amazon SQS retains a message. Integer representing seconds, from 60 (1 minute) to 1209600 (14 days) | `number` | `null` | no |

infrastructure/modules/sqs/sqs_queue.tf

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,8 @@ resource "aws_sqs_queue" "sqs_queue" {
77
fifo_queue = var.fifo_queue
88
content_based_deduplication = var.content_based_deduplication
99
max_message_size = var.max_message_size
10+
deduplication_scope = var.fifo_queue ? var.deduplication_scope : null
11+
fifo_throughput_limit = var.fifo_queue ? var.fifo_throughput_limit : null
1012

1113
kms_master_key_id = var.sqs_kms_key_arn
1214
kms_data_key_reuse_period_seconds = var.kms_data_key_reuse_period_seconds

infrastructure/modules/sqs/variables.tf

Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -110,3 +110,24 @@ variable "create_dlq" {
110110
type = bool
111111
default = false
112112
}
113+
114+
variable "deduplication_scope" {
115+
description = "For FIFO queues, specifies whether message deduplication occurs at the message group or queue level. Valid values are messageGroup and queue (default)."
116+
type = string
117+
default = "queue"
118+
119+
validation {
120+
condition = contains([], var.deduplication_scope)
121+
error_message = "deduplication_scope must be either \"queue\" or \"messageGroup\""
122+
}
123+
}
124+
variable "fifo_throughput_limit" {
125+
description = "For FIFO queues, specifies whether the FIFO queue throughput quota applies to the entire queue or per message group. Valid values are perQueue (default) and perMessageGroupId."
126+
type = string
127+
default = "perQueue"
128+
129+
validation {
130+
condition = contains([], var.fifo_throughput_limit)
131+
error_message = "fifo_throughput_limit must be either \"perQueue\" or \"perMessageGroup\""
132+
}
133+
}

0 commit comments

Comments
 (0)