Prefetch (QoS) ограничивает количество неподтвержденных сообщений, которые consumer может одновременно удерживать — это контролирует распределение работы и предотвращает перегрузку одного consumer'а в то время как другие простаивают. Это важно для справедливого и эффективного обработки сообщений.
Что делает prefetch
PREFETCH (QoS - prefetch count) → limits the number of UNACKNOWLEDGED messages a consumer
can have at once:
→ without it → RabbitMQ may dispatch many messages to one consumer (it grabs a batch)
→ with prefetch=N → a consumer gets at most N unacked messages at a time (must ack to get more)
→ controls how messages are distributed and how much a consumer buffers
