1
0
mirror of https://github.com/taigrr/nats.docs synced 2025-01-18 04:03:23 -08:00
Stephen Asbury 9618415569 Moved tools to _tools
Broke up develoepr doc into tree
Small CSS tweak to give diagrams more room
2019-05-15 12:22:57 -07:00

1.4 KiB

Draining Connections and Subscriptions

A new feature in the NATS client libraries is the ability to drain connections or subscriptions. Closing a connection, or unsubscribing from a subscription are generally considered immediate requests. Which means the library will halt messages in any pending queue or cache for subscribers. When you drain a subscription or connection, it will process any cached/pending messages before closing.

For a connection the process is essentially:

  1. Drain subscriptions
  2. Stop new messages from being published
  3. Flush any remaining messages
  4. Close

!INCLUDE "../../_examples/drain_conn.html"

Drain provides clients that use queue subscriptions with a way to bring down applications without losing any messages. A client can bring up a new queue member, drain and shut down the old queue member, all without losing messages sent to the old client. Without drain, there is the possibility of lost messages due to queue timing.

The mechanics of drain for a subscription are simpler:

  1. Unsubscribe at the server
  2. Process known messages
  3. Clean up

The API for drain can generally be used instead of unsubscribe:

!INCLUDE "../../_examples/drain_sub.html"

Because draining can involve messages flowing to the server, for a flush and asynchronous message processing, the timeout for drain should generally be higher than the timeout for a simple message request/reply or similar.