[ad_1]
With Amazon Easy Queue Service (Amazon SQS), you may ship, retailer, and obtain messages between software program parts at any quantity. At present, Amazon SQS has launched two new capabilities for first-in, first-out (FIFO) queues:
- Most throughput has been elevated as much as 70,000 transactions per second (TPS) per API motion in chosen AWS Areas, supporting sending or receiving as much as 700,000 messages per second with batching.
- Lifeless letter queue (DLQ) redrive assist to deal with messages that aren’t consumed after a particular variety of retries in a method just like what was already out there for normal queues.
Let’s take a extra in-depth have a look at how these work in observe.
FIFO queues throughput improve as much as 70K TPS
FIFO queues are designed for purposes that require messages to be processed precisely as soon as and within the order through which they’re despatched. Whereas customary queues have a limiteless throughput, FIFO queues have an higher quota within the variety of TPS per API motion.
Commonplace and FIFO queues assist batch actions that may ship and obtain as much as 10 messages with a single API name (as much as a most complete payload of 256 KB). Which means a FIFO queue can course of as much as 10 occasions extra messages per second than its most throughput.
At launch in 2016, FIFO queues supported as much as 300 TPS per API motion (3,000 messages per second with batching). This was sufficient for a lot of use circumstances, however some clients requested for extra throughput.
With excessive throughput mode launched in 2021, FIFO queues launched a tenfold improve of the utmost throughput and will course of as much as 3,000 TPS per API motion, relying on the Area. One 12 months later, that quota was doubled to as much as 6,000 TPS per API motion.
This 12 months, Amazon SQS has already elevated FIFO queue throughput quota two occasions, to as much as 9,000 TPS per API motion in August and as much as 18,000 TPS per API motion in October (relying on the Area).
At present, the Amazon SQS workforce has been in a position to improve the FIFO queue throughput quota once more, permitting you to course of as much as 70,000 TPS per API motion (as much as 700,000 messages per second with batching) within the US East (N. Virginia), US West (Oregon), and Europe (Eire) Areas. That is greater than 2 hundred occasions the utmost throughput at launch.
DLQ redrive assist for FIFO queues
With Amazon SQS, messages that aren’t consumed after a particular variety of retries can routinely be moved to a DLQ. There, messages may be analyzed to know the rationale why they haven’t been processed accurately. Typically there’s a bug or a misconfiguration within the client software. Different occasions the messages comprise invalid knowledge from the supply purposes that must be fastened to permit the messages to be processed once more.
Both method, you may outline a plan to reprocess these messages. For instance, you may repair the patron software and redrive all messages to the supply queue. Or you may create a devoted queue the place a customized software receives the messages, fixes their content material, after which sends them to the supply queue.
To simplify transferring the messages again to the supply queue or to a special queue, Amazon SQS lets you create a redrive process. Redrive duties are already out there for normal queues. Beginning right now, you too can begin a redrive process for FIFO queues.
Utilizing the Amazon SQS console, I create a primary queue (my-dlq.fifo
) for use as a DLQ. To redrive messages again to the supply FIFO queue, the queue sort should match, so that is additionally a FIFO queue.
Then, I create a supply FIFO queue (my-source-queue.fifo
) to deal with messages as normal. After I create the supply queue, I configure the primary queue (my-dlq.fifo
) because the DLQ and specify 3 because the Most receives situation below which messages are moved from the supply queue to the DLQ.
When a message has been acquired by a client for greater than the variety of occasions specified by this situation, Amazon SQS strikes the message to the DLQ. The unique message ID is retained and can be utilized to uniquely observe the message.
To check this setup, I exploit the console to ship a message to the supply queue. Then, I exploit the AWS Command Line Interface (AWS CLI) to obtain the message a number of occasions with out deleting it.
{
"Messages": [
{
"MessageId": "ef2f1c72-4bfe-4093-a451-03fe2dbd4d0f",
"ReceiptHandle": "...",
"MD5OfBody": "0f445a578fbcb0c06ca8aeb90a36fcfb",
"Body": "My important message."
}
]
}
To obtain the identical message greater than as soon as, I look ahead to the time specified within the queue visibility timeout to move (30 seconds by default).
After the third time, the message shouldn’t be within the supply queue as a result of it has been moved to the DLQ. When I attempt to obtain messages from the supply queue, the checklist is empty.
{
"Messages": []
}
To verify that the message has been moved, I ballot the DLQ to see if the message is there.
{
"Messages": [
{
"MessageId": "ef2f1c72-4bfe-4093-a451-03fe2dbd4d0f",
"ReceiptHandle": "...",
"MD5OfBody": "0f445a578fbcb0c06ca8aeb90a36fcfb",
"Body": "My important message."
}
]
}
Now that the message is within the DLQ, I can examine why the message has not been processed (effectively, I do know the rationale this time) and determine whether or not to redrive messages from the DLQ utilizing the Amazon SQS console or the brand new redrive API that was launched just a few months in the past. For this instance, I exploit the console. Again on the Amazon SQS console, I choose the DLQ queue and select Begin DLQ redrive.
In Redrive configuration, I select to redrive the messages to the supply queue. Optionally, I can specify one other FIFO queue as a customized vacation spot. I exploit System optimized in Velocity management settings to redrive messages with the utmost variety of messages per second optimized by Amazon SQS. Optionally, if there may be numerous messages within the DLQ, I can configure a customized most charge of messages per second to keep away from overloading customers.
Earlier than beginning the redrive process, I can use the Examine messages part to ballot and test messages. I already determined what to do, so I select DLQ redrive to start out the duty. I’ve just one message to course of, so the redrive process completes in a short time.
As anticipated, the message is again within the supply queue and is able to be processed once more.
Issues to know
Lifeless letter queue (DLQ) assist for FIFO queues is accessible right now in all AWS Areas the place Amazon SQS is obtainable except for GovCloud Areas and people primarily based in China.
Within the DLQ configuration, the utmost variety of receives must be between 1 and 1,000.
There isn’t any further price for utilizing excessive throughput mode or a DLQ. Each Amazon SQS motion counts as a request. A single request can ship or obtain from 1 to 10 messages, as much as a most complete payload of 256 KB. You pay primarily based on the variety of requests, and requests are priced in another way between customary and FIFO queues.
As a part of the AWS Free Tier, there isn’t a price for the primary million requests per 30 days for normal queues and for the primary million requests per 30 days for FIFO queues. For extra info, see Amazon SQS pricing.
With these updates and the elevated throughput, you may cowl the overwhelming majority of use circumstances with FIFO queues.
— Danilo
[ad_2]