Publish Subscribe

  • One publisher many readers

How

  • Client publishes something/message to a server and moves on, does not need to wait for it to be processed

    • This publisher does not know who picks it up, just that it will be picked up by those interested in it

  • Another client can register with the server and listen for a specific message and consume it

    • The reader/subscriber only knows there is a message that it wants and reads/consumes it

      • Depending on settings it will tell the server/broker when it has consumed it so it can be removed from the server

        • this is known as a queue

    • Does not know who it came from

    • Done via long polling or push

  • The server is often called the broker, it does not process the message, just receives and sends it on

  • Generally, the message removed from the server when all the readers/subscribers have received the message

    • Settings can be set to not remove and keep for a set time -> so new subscribers can get this message

Why

  • Lots of chatty applications, Especially for sending the same request to multiple servers

  • Due to lots of failures that can occur in req/resp using an intermediary (broker) reduced chattiness, lost messages etc

  • Decoupled the sender and receiver

  • Fire and forget mechanism allows for aysnc processing, the client does not have to wait for long processing of their request, the processing can be done in the background and take it's time (within reason)

    • if it needs information back, it can subscribe to another topic/queue/channel (Where the messages are published) to get it back at a later date

  • If there were lots of calls from one server to another, then req/resp will block waiting, lots of chnace of failure between communication downstream which will break the whole flow

  • Scale with multiple consumers/subscribers

    • if lots of unique messages need to be processed add more consumers

    • if one message needs to be handled in different independent ways can split the processing into different message consumers within an app or as separate applications (microserves)

  • Your client does not have to be running and your message will be processed

    • as long as it was sent to the broker

  • Your server can be down, but it will be processed

    • if on a queue it will sit there (although the queue can overfill if the publish keeps adding)

    • same for multiple subscribers if there was a time to live for the message

Issues

  • Two general problem

    • How do i know the message was delivered

  • Different guarantees

    • At least once guarantee - the message can be consumed by a subscriber twice, so adds complexity to handle this

      • ie idempotent, immutable

  • Added complexity

    • especially with handling sad paths, how to rollback

  • Another thing to maintain

  • The broker is point of failure

    • Can have persistent store, but slows performance

  • Harder to debug

    • need tracing, correlation id, message id

    • How to flow the full flow for a single starting message

Last updated

Was this helpful?