Invoking the first Lambda function via AWS Console or AWS CLI to send the message to an SQS Queue. The second Lambda function will be triggered once it receives the event message from the SQS Queue. The SQS Queue is configured as ".fifo" (First-In-First-Out), which means the messages are ordered based on message group ID and where duplicates can't be tolerated.
- Go to Lambda → Lambda Function → Test tab
- Update the Event JSON textarea field (see sample payload)
- Click on the Test button in the upper right corner
-
Use the following command and replace the placeholder
lambda_function_name
with the actual Lambda function nameaws lambda invoke \ --function-name lambda_function_name \ --payload '{"referenceId": "SMPLORDR-1234567890", "quantity": 1, "item": [{"id": "SMPLITM-12345", "name": "Sample Item", "price": 1234.50}]}' \ --cli-binary-format raw-in-base64-out \ response.json
- Payload
{
"referenceId": "SMPLORDR-1234567890",
"quantity": 1,
"item": [{
"id": "SMPLITM-12345",
"name": "Sample Item",
"price": 1234.50
}]
}
- CloudWatch Logs
{
"log_code": "SQSMessage",
"log_msg": "Received event from Amazon SQS",
"log_level": "INFO",
"log_keys": {
"eventSource": "aws:sqs",
"messageId": "9ab59c5d-4650-4e4f-abcd-bff95a6a4996",
"order": {
"referenceId": "SMPLORDR-1234567890",
"status": "RECEIVED",
"item": [
{
"id": "SMPLITM-12345",
"name": "Sample Item",
"price": 1234.5
}
],
"quantity": 1
}
},
"log_timestamp": "2023-04-26 02:33:00"
}
- SetQueueAttributes
- Exactly-once processing
- Using Lambda with Amazon SQS
- Amazon SQS dead-letter queues
- Amazon SQS visibility timeout
- Tutorial: Using Lambda with Amazon SQS
- Amazon SQS FIFO (First-In-First-Out) queues
npm run build
compile typescript to jsnpm run watch
watch for changes and compilenpm run test
perform the jest unit testscdk deploy
deploy this stack to your default AWS account/regioncdk diff
compare deployed stack with current statecdk synth
emits the synthesized CloudFormation template
-
Install all the dependencies, bootstrap your project, and synthesized CloudFormation template.
# Without passing "profile" parameter dev@dev:~:aws-cdk-samples/lambda/lambda-sqs$ make init # With "profile" parameter dev@dev:~:aws-cdk-samples/lambda/lambda-sqs$ make init profile=[profile_name]
-
Deploy the project.
# Without passing "profile" parameter dev@dev:~:aws-cdk-samples/lambda/lambda-sqs$ make deploy # With "profile" parameter dev@dev:~:aws-cdk-samples/lambda/lambda-sqs$ make deploy profile=[profile_name]