nats-io / nats-server

High-Performance server for NATS.io, the cloud and edge native messaging system.
https://nats.io
Apache License 2.0
16.03k stars 1.41k forks source link

Fix race with store when fetching messages by a consumer #6003

Closed Jarema closed 1 month ago

Jarema commented 1 month ago

We were releasing and acquiring again lock while fetching messages to reduce contention. This could cause a consumer getting stuck in certain scenarios, like when max messages per subject was set to 1 and message was republished while consumer was trying to NAK the first one.

Signed-off-by: Tomasz Pietrek tomasz@nats.io