【AWS】Lambda+SQS로 사일로+풀 모델을 실현하기 위한 디스패처 구성 검토
계기
data:image/s3,"s3://crabby-images/2bbda/2bbda0a19d8c7985c98de7288a37583f9f1346c6" alt=":man_tone1:"
현재 분석
3. 사일로 + 풀 모델을 목표로 하고 싶다.
검증에서 목표로 하는 구성
data:image/s3,"s3://crabby-images/59df5/59df542bb9ab128a0a72513b323eaa1026a9b8e7" alt=""
구축Step
1. 요청 수신 SQS와 Dispatcher용 Lambda를 연결
data:image/s3,"s3://crabby-images/0b077/0b077afcea8dc7b88c8d275f4cc8d33080dfdf2b" alt=""
data:image/s3,"s3://crabby-images/cdc96/cdc967553a809b85a86cc89ee22e2d653936e66b" alt=""
data:image/s3,"s3://crabby-images/32311/3231189544c86aa122892e8f46eaa2f2414cf44a" alt=""
index.js
exports.handler = async function(event, context) {
event.Records.forEach(record => {
const { body } = record;
console.log(body);
});
return {};
};
data:image/s3,"s3://crabby-images/fb37d/fb37d9051e3eef5539531b06d68a83decbeff594" alt=""
data:image/s3,"s3://crabby-images/a4db2/a4db21cfe9a24e09f767238c88ad9b609b873e52" alt=""
data:image/s3,"s3://crabby-images/4b6a2/4b6a2248e1d762fe7f2715807afe2f42efc27dc8" alt=""
data:image/s3,"s3://crabby-images/045db/045dbe38a83583d4c79bf5942d90a542ce9a881c" alt=""
2. Dispatcher용 Lambda에서 CompanyA용 SQS로 메시지 저장
data:image/s3,"s3://crabby-images/f0fe1/f0fe11aa3fd765d3bb7a4ad63d349ccd183a7bab" alt=""
data:image/s3,"s3://crabby-images/9cc52/9cc522419a27062fea33c7cc51290d8cb5f1c7f7" alt=""
index.js
const aws = require('aws-sdk');
aws.config.region = 'ap-northeast-1';
const sqs = new aws.SQS({apiVersion: '2012-11-05'});
const QUEUE_URL = 'https://sqs.ap-northeast-1.amazonaws.com/XXXXXXXXXX/companyA.fifo';
exports.handler = async function(event, context) {
const recs = event.Records;
for (let rec of recs){
const body = rec.body;
console.log(body);
const params = {
MessageBody: body,
QueueUrl: QUEUE_URL,
MessageGroupId:rec.attributes.MessageGroupId,
DelaySeconds: 0
};
console.log(params);
const result = await sqs.sendMessage(params).promise();
console.log(result)
}
};
data:image/s3,"s3://crabby-images/bf175/bf1757c8f4cb1ce10d71f2cc2dee52837f723d43" alt=""
data:image/s3,"s3://crabby-images/71b86/71b86ba9a373857d5b0fc1a824a270f00ea70ee1" alt=""
data:image/s3,"s3://crabby-images/be25a/be25af6f36a2649fa79db3a487d5a5f943266ea5" alt=""
3. Dispatcher용 Lambda에서 수신 메시지에 따라 저장
data:image/s3,"s3://crabby-images/25420/2542026645cb05aaa1f9d2ee1a3db1f87cf57193" alt=""
data:image/s3,"s3://crabby-images/1a989/1a989462134f6aef17c8cac0acbc736125223dac" alt=""
index.js
const aws = require('aws-sdk');
aws.config.region = 'ap-northeast-1';
const sqs = new aws.SQS({apiVersion: '2012-11-05'});
const companyA_QUEUE_URL = 'https://sqs.ap-northeast-1.amazonaws.com/XXXXXXXXXX/companyA.fifo';
const companyOTHERS_QUEUE_URL = 'https://sqs.ap-northeast-1.amazonaws.com/XXXXXXXXXX/companyOTHER.fifo';
let queue_url = '';
exports.handler = async function(event, context) {
const recs = event.Records;
for (let rec of recs){
const body = rec.body;
console.log(body);
const body_parse = JSON.parse(body);
if(body_parse.company_code === '0001'){
queue_url = companyA_QUEUE_URL;
} else {
queue_url = companyOTHERS_QUEUE_URL;
}
const params = {
MessageBody: body,
QueueUrl: queue_url,
MessageGroupId:rec.attributes.MessageGroupId,
DelaySeconds: 0
};
console.log(params);
const result = await sqs.sendMessage(params).promise();
console.log(result)
}
};
data:image/s3,"s3://crabby-images/983fb/983fb4fdc48fa62fb2f568bda073a155739967ad" alt=""
data:image/s3,"s3://crabby-images/48231/4823130be28de5e97dc414aa88ab03c4105c23ae" alt=""
data:image/s3,"s3://crabby-images/66be8/66be89b46b6991638effa43f385105f2a96d08cb" alt=""
data:image/s3,"s3://crabby-images/a3300/a3300b2995fee8015a6c954f6cc395d26d5cefb7" alt=""
data:image/s3,"s3://crabby-images/1ce39/1ce39eabdd598b9ac0fd182ee50e83d8b99ca574" alt=""
참고 사이트
Reference
이 문제에 관하여(【AWS】Lambda+SQS로 사일로+풀 모델을 실현하기 위한 디스패처 구성 검토), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/kei1-dev/items/c48c30cd8faf090742a3텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)