You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The paused state and time time would need to be persisted to the raft layer such that server restarts would not unpause paused consumers. This is done using the consumer configuration that has a new value:
PauseUntil time.Time json:"pause_until,omitempty"
If in doubt, refer to the Server/Schema PR
Feature be available in the server version 2.11
Hints
Probably the easiest way to implement it, is to look how calls to methods for creating / deleting streams and consumers are done.
Use case
It is difficult to schedule maintenance on central resources on a large distributed system where 100s or 1000s of clients are accessing data in a stream.
This change allows to pause a Consumer such that it appears healthy but just doesnt deliver any messages.
During the pause maintenance can happen and resources accessed by clients will not be under constant pressure, later the stream can be unpaused and work will continue.
This happen without impacting running clients - other than they would see pending messages in stream info but not get any deliveries.
Applies to push and pull consumers.
Contribution
No response
The text was updated successfully, but these errors were encountered:
Proposed change
Implement the new API for pausing consumers.
The Server PR with related change has been merged here: nats-io/nats-server#5066
Schemas PR, which is probably the best source of information how to implement the feature:
https://github.com/nats-io/jsm.go/pull/522/files
ADR issue: nats-io/nats-architecture-and-design#266
Details
Request and response schemas:
Consumer info includes 2 new fields:
The paused state and time time would need to be persisted to the raft layer such that server restarts would not unpause paused consumers. This is done using the consumer configuration that has a new value:
If in doubt, refer to the Server/Schema PR
Feature be available in the server version 2.11
Hints
Probably the easiest way to implement it, is to look how calls to methods for creating / deleting streams and consumers are done.
Use case
It is difficult to schedule maintenance on central resources on a large distributed system where 100s or 1000s of clients are accessing data in a stream.
This change allows to pause a Consumer such that it appears healthy but just doesnt deliver any messages.
During the pause maintenance can happen and resources accessed by clients will not be under constant pressure, later the stream can be unpaused and work will continue.
This happen without impacting running clients - other than they would see pending messages in stream info but not get any deliveries.
Applies to push and pull consumers.
Contribution
No response
The text was updated successfully, but these errors were encountered: