- vừa được xem lúc

Blog#103: AWS SQS: The Ultimate Guide for Junior Developers

0 0 28

Người đăng: NGUYỄN ANH TUẤN

Theo Viblo Asia

Hi, I'm Tuan, a Full-stack Web Developer from Tokyo 😊. Follow my blog to not miss out on useful and interesting articles in the future.

AWS Simple Queue Service (SQS) is a fully managed message queuing service that enables you to decouple and scale microservices, distributed systems, and serverless applications. SQS eliminates the complexity and overhead associated with managing and operating message oriented middleware, and empowers developers to focus on differentiating work.

Node.js is a JavaScript runtime built on Chrome's V8 JavaScript engine. It allows developers to run JavaScript on the server-side to create fast and scalable network applications. Node.js is widely used for creating back-end services, building real-time apps, and running automation tasks.

By using SQS and Node.js together, you can create powerful and flexible applications that can handle and process large amounts of data and perform multiple tasks simultaneously.

Setting up an SQS Queue in AWS

Before you can use SQS with Node.js, you need to create a new queue in AWS. You can do this by following these steps:

  1. Go to the SQS homepage in the AWS Management Console.
  2. Click the "Create Queue" button.
  3. Give your queue a name, and select the "Standard Queue" option.
  4. Click the "Create Queue" button to create your new queue.

Once your queue is set up, you can start sending and receiving messages to and from it.

Sending Messages to an SQS Queue in Node.js

To send a message to an SQS queue from a Node.js application, you need to use the AWS SDK for JavaScript in Node.js (aws-sdk). The SDK provides a client for SQS that you can use to interact with SQS using Node.js.

Here's an example of how to send a message to an SQS queue using the SDK:

const AWS = require('aws-sdk');
const sqs = new AWS.SQS(); // Create the message to send to the SQS queue
const message = { message: 'Hello, SQS!'
}; // Set the parameters for sending the message to the SQS queue
const params = { MessageBody: JSON.stringify(message), QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/MyQueue'
}; // Send the message to the SQS queue
sqs.sendMessage(params, (err, data) => { if (err) { console.log(`Error sending message to SQS: ${err}`); } else { console.log(`Successfully sent message to SQS: ${data}`); }
});

Receiving and Processing Messages from an SQS Queue in Node.js

Once you've sent messages to your SQS queue, you can receive and process them in a Node.js application using the AWS SDK for JavaScript in Node.js (aws-sdk).

Here's an example of how to poll an SQS queue for new messages and process each message as it's received:

const AWS = require('aws-sdk');
const sqs = new AWS.SQS(); // Set the parameters for receiving messages from the SQS queue
const params = { QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/MyQueue', MaxNumberOfMessages: 10
}; // Poll the SQS queue for new messages
setInterval(() => { sqs.receiveMessage(params, (err, data) => { if (err) { console.log(`Error receiving message from SQS: ${err}`); } else { console.log(`Successfully received message from SQS: ${data}`); // Process the message // ... } });
}, 5000);

In this example, the setInterval function is used to poll the SQS queue for new messages every 5 seconds. When a message is received, it is logged to the console and then processed by the application.

Use Cases

1. Background Job Processing

SQS can be used to process background jobs asynchronously in a Node.js application. For example, sending an email, generating reports, and cleaning up old data.

In this use case, you can use SQS to process background jobs asynchronously in a Node.js application. For example, sending an email:

const AWS = require('aws-sdk');
const sqs = new AWS.SQS();
const ses = new AWS.SES(); // Create the message to send to the SQS queue
const message = { email: 'example@example.com', subject: 'Hello, SQS!', body: 'This is a background job processed by SQS'
}; // Set the parameters for sending the message to the SQS queue
const params = { MessageBody: JSON.stringify(message), QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/emailQueue'
}; // Send the message to the SQS queue
sqs.sendMessage(params, (err, data) => { if (err) { console.log(`Error sending message to SQS: ${err}`); } else { console.log(`Successfully sent message to SQS: ${data}`); }
}); setInterval(() => { sqs.receiveMessage({ QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/emailQueue', MaxNumberOfMessages: 10 }, (err, data) => { if (err) { console.log(`Error receiving message from SQS: ${err}`); } else { const emailParams = { Destination: { ToAddresses: [data.Messages[0].email] }, Message: { Body: { Text: { Charset: "UTF-8", Data: data.Messages[0].body } }, Subject: { Charset: 'UTF-8', Data: data.Messages[0].subject } }, Source: 'example@example.com', }; ses.sendEmail(emailParams, (err, data) => { if (err) { console.log(`Error sending email: ${err}`); } else { console.log(`Successfully sent email: ${data}`); } }); sqs.deleteMessage({ QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/emailQueue', ReceiptHandle: data.Messages[0].ReceiptHandle }, (err, data) => { if (err) { console.log(`Error deleting email from SQS: ${err}`); } else { console.log(`Successfully deleted email from SQS: ${data}`); } }); } });
}, 5000);

2. Decoupling Microservices

SQS can be used to decouple microservices in a Node.js application by using SQS as a messaging bus between services. This allows services to operate independently and improves the scalability and availability of the overall application.

In this use case, you can use SQS as a messaging bus between different microservices in a Node.js application. This allows the microservices to operate independently and improves the scalability and availability of the overall application. Here's an example of how one microservice could send a message to another using SQS:

const AWS = require('aws-sdk');
const sqs = new AWS.SQS(); // Create the message to send to the SQS queue
const message = { message: 'This is a message from Microservice 1 to Microservice 2'
}; // Set the parameters for sending the message to the SQS queue
const params = { MessageBody: JSON.stringify(message), QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/microserviceQueue'
}; // Send the message to the SQS queue
sqs.sendMessage(params, (err, data) => { if (err) { console.log(`Error sending message to SQS: ${err}`); } else { console.log(`Successfully sent message to SQS: ${data}`); }
});

3. Real-time Notification

SQS can be used to send real-time notifications to a Node.js application when certain events occur. For example, sending a notification when a new user signs up, or when a payment is received.

In this use case, you can use SQS to send real-time notifications to a Node.js application when certain events occur. For example, sending a notification when a new user signs up:

const AWS = require('aws-sdk');
const sqs = new AWS.SQS(); // Create the message to send to the SQS queue
const message = { message: 'A new user has signed up: John Doe'
}; // Set the parameters for sending the message to the SQS queue
const params = { MessageBody: JSON.stringify(message), QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/notificationQueue'
}; // Send the message to the SQS queue
sqs.sendMessage(params, (err, data) => { if (err) { console.log(`Error sending message to SQS: ${err}`); } else { console.log(`Successfully sent message to SQS: ${data}`); }
}); // Poll the SQS queue for new messages
setInterval(() => { sqs.receiveMessage({ QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/notificationQueue', MaxNumberOfMessages: 10 }, (err, data) => { if (err) { console.log(`Error receiving message from SQS: ${err}`); } else { console.log(`Received notification: ${data.Messages[0].message}`); // send this notification to client //... sqs.deleteMessage({ QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/notificationQueue', ReceiptHandle: data.Messages[0].ReceiptHandle }, (err, data) => { if (err) { console.log(`Error deleting notification from SQS: ${err}`); } else { console.log(`Successfully deleted notification from SQS: ${data}`); } }); } });
}, 5000);

4. Automated Workflows

SQS can be used to create automated workflows in a Node.js application. For example, processing a user's image and sending it to another service for analysis.

In this use case, you can use SQS to create automated workflows in a Node.js application. For example, processing a user's image and sending it to another service for analysis:

const AWS = require('aws-sdk');
const sqs = new AWS.SQS();
const rekognition = new AWS.Rekognition(); // Create the message to send to the SQS queue
const message = { imageUrl: 'https://example.com/image.jpg'
}; // Set the parameters for sending the message to the SQS queue
const params = { MessageBody: JSON.stringify(message), QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/imageQueue'
}; // Send the message to the SQS queue
sqs.sendMessage(params, (err, data) => { if (err) { console.log(`Error sending message to SQS: ${err}`); } else { console.log(`Successfully sent message to SQS: ${data}`); }
}); setInterval(() => { sqs.receiveMessage({ QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/imageQueue', MaxNumberOfMessages: 10 }, (err, data) => { if (err) { console.log(`Error receiving message from SQS: ${err}`); } else { const imageUrl = data.Messages[0].imageUrl; rekognition.detectLabels({ Image: { S3Object: { Bucket: 'imageBucket', Name: imageUrl } }, MinConfidence: 90 }, (err, data) => { if (err) { console.log(`Error processing image: ${err}`); } else { console.log(`Image labels: ${data.Labels}`); } }); sqs.deleteMessage({ QueueUrl: 'https://sqs.us-east-1.amazonaws.com/1234567890/imageQueue', ReceiptHandle: data.Messages[0].ReceiptHandle }, (err, data) => { if (err) { console.log(`Error deleting image from SQS: ${err}`); } else { console.log(`Successfully deleted image from SQS: ${data}`); } }); } });
}, 5000);

5. Load Balancing

SQS can be used as a load balancer in a Node.js application by routing incoming requests to multiple instances of the application. This allows the application to scale automatically to handle large amounts of traffic.

In this use case, you can use SQS as a load balancer in a Node.js application by routing incoming requests to multiple instances of the application. This allows the application to scale automatically to handle large amounts of traffic. Here's an example of how to route incoming requests to different instances of a Node.js application:

const AWS = require("aws-sdk");
const sqs = new AWS.SQS(); // Create the SQS queue
sqs.createQueue( { QueueName: "requestQueue", }, (err, data) => { if (err) { console.log(`Error creating SQS queue: ${err}`); } else { console.log(`Successfully created SQS queue: ${data}`); } }
); // Send a request to the SQS queue
const request = { requestUrl: "/example", requestMethod: "GET",
}; const params = { MessageBody: JSON.stringify(request), QueueUrl: "https://sqs.us-east-1.amazonaws.com/1234567890/requestQueue",
}; sqs.sendMessage(params, (err, data) => { if (err) { console.log(`Error sending request to SQS: ${err}`); } else { console.log(`Successfully sent request to SQS: ${data}`); }
}); // Poll the SQS queue for new requests
setInterval(() => { sqs.receiveMessage( { QueueUrl: "https://sqs.us-east-1.amazonaws.com/1234567890/requestQueue", MaxNumberOfMessages: 10, }, (err, data) => { if (err) { console.log(`Error receiving request from SQS: ${err}`); } else { // Route request to a free instance of the application //... sqs.deleteMessage( { QueueUrl: "https://sqs.us-east-1.amazonaws.com/1234567890/requestQueue", ReceiptHandle: data.Messages[0].ReceiptHandle, }, (err, data) => { if (err) { console.log(`Error deleting request from SQS: ${err}`); } else { console.log(`Successfully deleted request from SQS: ${data}`); } } ); } } );
}, 5000);

As you can see in the code samples, AWS SQS can be used for various use cases like background job processing, decoupling microservices, real-time notifications, automated workflows, and load balancing. The code samples I've provided are just a starting point and can be customized to meet the specific requirements of your application.

Conclusion

In this article, we've discussed how AWS Simple Queue Service (SQS) and Node.js can be used together to create powerful and flexible applications. We've shown how to create an SQS queue in AWS, how to send and receive messages to and from the queue using Node.js, and we've provided real-world use cases where SQS can be used to solve common problems. Remember that SQS is a fully managed service and it can help you to build microservices and scalable applications.

I hope this information helps you to understand the basics of using SQS and Node.js together and give you a foundation for creating your own applications. If you want to learn more about SQS and Node.js, I recommend you check out the official AWS SQS and AWS SDK for Node.js documentation.

As always, I hope you enjoyed this article and learned something new. Thank you and see you in the next articles!

If you liked this article, please give me a like and subscribe to support me. Thank you. 😊

Ref

Bình luận

Bài viết tương tự

- vừa được xem lúc

Cài đặt WSL / WSL2 trên Windows 10 để code như trên Ubuntu

Sau vài ba năm mình chuyển qua code trên Ubuntu thì thật không thể phủ nhận rằng mình đã yêu em nó. Cá nhân mình sử dụng Ubuntu để code web thì thật là tuyệt vời.

0 0 396

- vừa được xem lúc

Hướng dẫn làm bot Facebook messenger cho tài khoản cá nhân

Giới thiệu. Trong bài viết trước thì mình có hướng dẫn các bạn làm chatbot facebook messenger cho fanpage. Hôm nay mình sẽ hướng dẫn các bạn tạo chatbot cho một tài khoản facebook cá nhân. Chuẩn bị.

0 0 195

- vừa được xem lúc

Crawl website sử dụng Node.js và Puppeteer - phần 2

trong phần 1 mình đã giới thiệu về puppeteer và tạo được 1 project cùng một số file đầu tiên để các bạn có thể crawl dữ liệu từ một trang web bất kỳ. Bài này mình sẽ tiếp nối bài viết trước để hoàn thiện seri này.

0 0 73

- vừa được xem lúc

Điều React luôn giữ kín trong tim

■ Mở đầu. Ngồi viết bài khi đang nghĩ vu vơ chuyện con gà hay quả trứng có trước, mình phân vân chưa biết sẽ chọn chủ đề gì để chúng ta có thể cùng nhau bàn luận.

0 0 59

- vừa được xem lúc

Gửi Mail với Nodejs và AWS SES

AWS SES. AWS SES là gì.

0 0 83

- vừa được xem lúc

Crawl website sử dụng Node.js và Puppeteer - phần 1

Bài viết này mình sẽ giới thiệu cho các bạn craw dữ liệu của web site sử dụng nodejs và Puppeteer. .

0 0 164