Page MenuHomeSoftware Heritage

Use better kafka producer semantics in the journal writers
ClosedPublic

Authored by olasd on Mar 10 2020, 7:41 PM.

Details

Summary

What we really want is for the broker to acknowledge all messages before we go
on to the next step. That's accomplished by flushing the producer rather than
enabling idempotence (which has other side-effects, such as only-once delivery,
which we don't really care about as all our consumers are, in effect,
idempotent).

Setting acks to all means that the broker acknowledges that all in-sync replicas
have persisted the message, which is a stronger guarantee than what we had
before.

Depends on D2808

Test Plan

This seems to have alleviated our broker memory consumption issues in
production.

Diff Detail

Repository
rDJNL Journal infrastructure
Branch
uffizi
Lint
No Linters Available
Unit
No Unit Test Coverage
Build Status
Buildable 11043
Build 16635: tox-on-jenkinsJenkins
Build 16634: arc lint + arc unit