Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Slide DevCoach
Search
shabilla
April 11, 2024
0
10
Slide DevCoach
DevCoach 129 : Back-End | Membangun aplikasi modern dengan Message Queue
shabilla
April 11, 2024
Tweet
Share
More Decks by shabilla
See All by shabilla
Slide DevCoach #151
shabillarestu
0
45
Slide DevCoach
shabillarestu
0
43
Slide DevCoach
shabillarestu
0
25
Slide DevCoach
shabillarestu
0
26
Slide DevCoach
shabillarestu
0
20
Slide DevCoach
shabillarestu
0
15
Slide DevCoach
shabillarestu
0
22
Slide DevCoach
shabillarestu
0
19
Slide DevCoach
shabillarestu
0
22
Featured
See All Featured
Building Adaptive Systems
keathley
41
2.6k
Producing Creativity
orderedlist
PRO
346
40k
Become a Pro
speakerdeck
PRO
28
5.4k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
6
660
How STYLIGHT went responsive
nonsquared
100
5.6k
Sharpening the Axe: The Primacy of Toolmaking
bcantrill
42
2.3k
How to Think Like a Performance Engineer
csswizardry
23
1.6k
Designing for humans not robots
tammielis
253
25k
YesSQL, Process and Tooling at Scale
rocio
172
14k
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
The Cult of Friendly URLs
andyhume
78
6.4k
Typedesign – Prime Four
hannesfritz
41
2.6k
Transcript
None
None
“Everything fails, all the time”. - Werner Vogels, CTO and
Vice President Amazon. Back-End
Agenda • Mengenal message queue • Mengenal RabbitMQ • Implementasi
message queue pada REST API Back-End
Back-End Message Queue
What is Message Queue? Message queue adalah bentuk komunikasi asynchronous
antar layanan (services) yang biasanya digunakan pada arsitektur microservices. Back-End
Back-End Apa contoh penerapannya di kehidupan sehari-hari?? 🤔
Why Message Queue? • Memisahkan (decoupling). • Keandalan (Reliability). •
Skalabilitas (Scalability). Back-End
Message Queue Use Case • Ecommerce: order process, shipping, invoice,
dll. • Financial services: transaction processing. • Analytics: user log. Back-End
When to Use Message Queue? • Pengguna Sudah Ribuan •
Asynchronous Proses • Microservices Arsitektur • Analytics Back-End
Back-End Message Queue Type
Point-to-point Point-to-point messaging adalah pola distribusi yang digunakan dalam message
queue. Point-to-point messaging memiliki hubungan one-to-one antara pengirim dan penerima pesan (disebut juga sebagai producer dan consumer). Back-End
Publish/subscribe Publish/subscribe adalah pola message queue yang memungkinkan pesan untuk
di-broadcast ke berbagai bagian sistem secara asinkron. Pesan apa pun yang di-publish ke suatu topic akan segera diterima oleh semua yang subscribe ke topik tersebut. Back-End
Message Queue Component Producer Queue Consumer
Back-End Rabbit MQ
RabbitMQ Back-End RabbitMQ adalah salah satu message broker open-source yang
populer digunakan. RabbitMQ dapat mendukung banyak protokol seperti AMQP, STOMP, MQTT, HTTP, dan WebSocket.
Install RabbitMQ Back-End docker pull rabbitmq:management docker run --name rabbitmq
-p 5672:5672 -p 15672:15672 -d rabbitmq:management
Back-End Demo RabbitMQ di REST API https://github.com/arasopraza/Demo-Developer-Coaching-129.git
Menghubungkan RabbitMQ const connection = await amqp.connect(process.env.RABBITMQ_SERVER); const channel =
await connection.createChannel(); await channel.assertQueue(queue, { durable: true, }); await channel.sendToQueue(queue, Buffer.from(message));
Menghubungkan Consumer ke RabbitMQ const connection = await amqp.connect(process.env.RABBITMQ_SERVER); const
channel = await connection.createChannel(); await channel.assertQueue('order:confirm', { durable: true, }); channel.consume('order:confirm', listener.listen, { noAck: true });
Feedback! Hadiah: • 2 Token Langganan Academy (30 Hari) *untuk
pengisi feedback terpilih! dicoding.id/devcoachfeedback
Thank You arasopraza
[email protected]
arasopraza Back-End arsyopraza