Use Cases
- Distributing workloads—distribute tasks between workers
- Asynchronous workflows—e.g. order fulfilment
- Distributing event notifications—alert other services that something has happened, e.g. order placed
- Distributed logging—distribute to log archives, analytics etc.
- Data device streaming—IoT, consumed on demand
- Increases resilience of applications—loose coupling between services
Pub/Sub Patterns
One-to-One
data:image/s3,"s3://crabby-images/22d32/22d32c17d075993102d68461a2fa179cfa19217c" alt="pub_sub_one_to_one"
One-to-Many
Each Subscriber Receives a Copy of Every Message
data:image/s3,"s3://crabby-images/42a2b/42a2b8156ea6294691f777587a4713b09068ed49" alt="pub_sub_one_to_many"
Round Robin Message Delivery
data:image/s3,"s3://crabby-images/be8d5/be8d5e32a54be7cb397cfaf6c37dcfec7d7ab526" alt="pub_sub_one_to_many_round_robin"
Many-to-Many
data:image/s3,"s3://crabby-images/b0dac/b0dacfffab00cf32407e4830db73ae8348891628" alt="pub_sub_many_to_many"
Many-to-One
data:image/s3,"s3://crabby-images/a333b/a333b74bad50588cbf33a34b0dae92f0f67fc24b" alt="pub_sub_many_to_one"
Subscription Types
- Pull—subscriber makes request via subscription to check for new messages
- Push—auto send messages to HTTP endpoint