A high level summary of noteworthy changes in each version.
- NOTE
-
Dependency version bumps are not listed here.
-
fix: Fix equality and hash code for ShardKey with array key (#638), resolves (#579)
-
fix: Fix target loading computation for inflight records (#662)
-
fix: Fix synchronisation logic for transactional producer commit affecting non-transactional usage (#665), resolves (#637)
-
fix: Fix for race condition in partition state clean/dirty tracking (#666), resolves (#664)
-
fix: Return cached pausedPartitionSet (#620), resolves (#618)
-
fix: Parallel consumer stops processing data sometimes (#623), fixes (#606)
-
fix: Add synchronization to ensure proper intializaiton and closing of PCMetrics singleton (#627), fixes (#617)
-
fix: Readme - metrics example correction (#614)
-
fix: Remove micrometer-atlas dependency (#628), fixes (#625)
-
feature: Micrometer metrics (#594)
-
feature: Adds an option to pass an invalid offset metadata error policy (#537), improves (#326)
-
feature: Lazy intialization of workerThreadPool (#531)
-
fix: Don’t drain mode shutdown kills inflight threads (#559)
-
fix: Drain mode shutdown doesn’t pause consumption correctly (#552)
-
fix: RunLength offset decoding returns 0 base offset after no-progress commit - related to (#546)
-
fix: Transactional PConsumer stuck while rebalancing - related to (#541)
-
fixes: #195 NoSuchFieldException when using consumer inherited from KafkaConsumer (#469)
-
fix: After new performance fix PR#530 merges - corner case could cause out of order processing (#534)
-
fix: Cleanup WorkManager’s count of in-progress work, when work is stale after partition revocation (#547)
-
feature: Simple PCRetriableException to remove error spam from logs (#444)
-
minor: fixes #486: Missing generics in JStreamParallelStreamProcessor #491
-
minor: partially address #459: Moves isClosedOrFailed into top level ParallelConsumer interface (#491)
-
tests: Demonstrates how to use MockConsumer with PC for issue #176
-
other minor improvements
-
fixes #409: Adds support for compacted topics and commit offset resetting (#425)
-
Truncate the offset state when bootstrap polled offset higher or lower than committed
-
Prune missing records from the tracked incomplete offset state, when they’re missing from polled batches
-
-
fix: Improvements to encoding ranges (int vs long) #439
-
Replace integer offset references with long - use Long everywhere we deal with offsets, and where we truncate down, do it exactly, detect and handle truncation issues.
-
-
Transactional commit mode system improvements and docs (#355)
-
Clarifies transaction system with much better documentation.
-
Fixes a potential race condition which could cause offset leaks between transactions boundaries.
-
Introduces lock acquisition timeouts.
-
Fixes a potential issue with removing records from the retry queue incorrectly, by having an inconsistency between compareTo and equals in the retry TreeMap.
-
-
Adds a very simple Dependency Injection system modeled on Dagger (#398)
-
Various refactorings e.g. new ProducerWrap
-
Dependencies
-
build(deps): prod: zstd, reactor, dev: podam, progressbar, postgresql maven-plugins: versions, help (#420)
-
build(deps-dev): bump postgresql from 42.4.1 to 42.5.0
-
bump podam, progressbar, zstd, reactor
-
build(deps): bump versions-maven-plugin from 2.11.0 to 2.12.0
-
build(deps): bump maven-help-plugin from 3.2.0 to 3.3.0
-
build(deps-dev): bump Confluent Platform Kafka Broker to 7.2.2 (#421)
-
build(deps): Upgrade to AK 3.3.0 (#309)
-
-
fixes #184: Fix multi topic subscription with KEY order by adding topic to shard key (#315)
-
fixes #329: Committing around transaction markers causes encoder to crash (#328)
-
build: Upgrade Truth-Generator to 0.1.1 for user Subject discovery (#332)
-
build: Allow snapshots locally, fail in CI (#331)
-
build: OSS Index scan change to warn only and exclude Guava CVE-2020-8908 as it’s WONT_FIX (#330)
-
build(deps): bump reactor-core from 3.4.19 to 3.4.21 (#344)
-
build(deps): dependabot bump Mockito, Surefire, Reactor, AssertJ, Release (#342) (#342)
-
build(deps): dependabot bump TestContainers, Vert.x, Enforcer, Versions, JUnit, Postgress (#336)
-
#225: Build and runtime support for Java 16+ (#289)
-
#306: Change Truth-Generator dependency from compile to test
-
#298: Improve PollAndProduce performance by first producing all records, and then waiting for the produce results.Previously, this was done for each ProduceRecord individually.
-
feature: Poll Context object for API (#223)
-
PollContext API - provides central access to result set with various convenience methods as well as metadata about records, such as failure count
-
-
major: Batching feature and Event system improvements
-
Batching - all API methods now support batching. See the Options class set batch size for more information.
-
-
Event system - better CPU usage in control thread
-
Concurrency stability improvements
-
Update dependencies
-
#247: Adopt Truth-Generator (#249)
-
Adopt Truth Generator for automatic generation of Google Truth Subjects
-
-
Large rewrite of internal architecture for improved maintence and simplicity which fixed some corner case issues
-
refactor: Rename PartitionMonitor to PartitionStateManager (#269)
-
refactor: Queue unification (#219)
-
refactor: Partition state tracking instead of search (#218)
-
refactor: Processing Shard object
-
-
fix: Concurrency and State improvements (#190)
-
Add option to specify timeout for how long to wait offset commits in periodic-consumer-sync commit-mode
-
Add option to specify timeout for how long to wait for blocking Producer#send
-
Project Reactor non-blocking threading adapter module
-
Generic Vert.x Future support - i.e. FileSystem, db etc…
-
Vert.x concurrency control via WebClient host limits fixed - see #maxCurrency
-
Vert.x API cleanup of invalid usage
-
Out of bounds for empty collections
-
Use ConcurrentSkipListMap instead of TreeMap to prevent concurrency issues under high pressure
-
log: Show record topic in slow-work warning message
-
Major refactor to code base - primarily the two large God classes
-
Partition state now tracked separately
-
Code moved into packages
-
-
Busy spin in some cases fixed (lower CPU usage)
-
Reduce use of static data for test assertions - remaining identified for later removal
-
Various fixes for parallel testing stability
-
Tests now run in parallel
-
License fixing / updating and code formatting
-
License format runs properly now when local, check on CI
-
Fix running on Windows and Linux
-
Fix JAVA_HOME issues
-
tests: Enable the fail fast feature now that it’s merged upstream
-
tests: Turn on parallel test runs
-
format: Format license, fix placement
-
format: Apply Idea formatting (fix license layout)
-
format: Update mycila license-plugin
-
test: Disable redundant vert.x test - too complicated to fix for little gain
-
test: Fix thread counting test by closing PC @After
-
test: Test bug due to static state overrides when run as a suite
-
format: Apply license format and run every All Idea build
-
format: Organise imports
-
fix: Apply license format when in dev laptops - CI only checks
-
fix: javadoc command for various OS and envs when JAVA_HOME missing
-
fix: By default, correctly run time JVM as jvm.location
-
ci: Add CODEOWNER
-
fix: #101 Validate GroupId is configured on managed consumer
-
Use 8B1DA6120C2BF624 GPG Key For Signing
-
ci: Bump jdk8 version path
-
fix: #97 Vert.x thread and connection pools setup incorrect
-
Disable Travis and Codecov
-
ci: Apache Kafka and JDK build matrix
-
fix: Set Serdes for MockProducer for AK 2.7 partition fix KAFKA-10503 to fix new NPE
-
Only log slow message warnings periodically, once per sweep
-
Upgrade Kafka container version to 6.0.2
-
Clean up stalled message warning logs
-
Reduce log-level if no results are returned from user-function (warn → debug)
-
Enable java 8 Github
-
Fixes #87 - Upgrade UniJ version for UnsupportedClassVersion error
-
Bump TestContainers to stable release to specifically fix #3574
-
Clarify offset management capabilities
-
fixes #62: Off by one error when restoring offsets when no offsets are encoded in metadata
-
fix: Actually skip work that is found as stale
-
Queueing and pressure system now self tuning, performance over default old tuning values (
softMaxNumberMessagesBeyondBaseCommitOffset
andmaxMessagesToQueue
) has doubled.-
These options have been removed from the system.
-
-
Offset payload encoding back pressure system
-
If the payload begins to take more than a certain threshold amount of the maximum available, no more messages will be brought in for processing, until the space need beings to reduce back below the threshold. This is to try to prevent the situation where the payload is too large to fit at all, and must be dropped entirely.
-
See Proper offset encoding back pressure system so that offset payloads can’t ever be too large #47
-
Messages that have failed to process, will always be allowed to retry, in order to reduce this pressure.
-
-
Default ordering mode is now
KEY
ordering (wasUNORDERED
).-
This is a better default as it’s the safest mode yet high performing mode. It maintains the partition ordering characteristic that all keys are processed in log order, yet for most use cases will be close to as fast as
UNORDERED
when the key space is large enough.
-
-
Support BitSet encoding lengths longer than Short.MAX_VALUE #37 - adds new serialisation formats that supports wider range of offsets - (32,767 vs 2,147,483,647) for both BitSet and run-length encoding.
-
Commit modes have been renamed to make it clearer that they are periodic, not per message.
-
Minor performance improvement, switching away from concurrent collections.
-
Bitset overflow check (#35) - gracefully drop BitSet or Runlength encoding as an option if offset difference too large (short overflow)
-
A new serialisation format will be added in next version - see Support BitSet encoding lengths longer than Short.MAX_VALUE #37
-
-
Gracefully drops encoding attempts if they can’t be run
-
Fixes a bug in the offset drop if it can’t fit in the offset metadata payload
-
Turns back on the Bitset overflow check (#35)
-
Incorrectly turns off an over-flow check in offset serialisation system (#35)
-
Choice of commit modes: Consumer Asynchronous, Synchronous and Producer Transactions
-
Producer instance is now optional
-
Using a transactional Producer is now optional
-
Use the Kafka Consumer to commit
offsets
Synchronously or Asynchronously
-
Memory performance - garbage collect empty shards when in KEY ordering mode
-
Select tests adapted to non transactional (multiple commit modes) as well
-
Adds supervision to broker poller
-
Fixes a performance issue with the async committer not being woken up
-
Make committer thread revoke partitions and commit
-
Have onPartitionsRevoked be responsible for committing on close, instead of an explicit call to commit by controller
-
Make sure Broker Poller now drains properly, committing any waiting work
-
Fixes bug in commit linger, remove genesis offset (0) from testing (avoid races), add ability to request commit
-
Fixes #25 confluentinc#25:
-
Sometimes a transaction error occurs - Cannot call send in state COMMITTING_TRANSACTION #25
-
-
ReentrantReadWrite lock protects non-thread safe transactional producer from incorrect multithreaded use
-
Wider lock to prevent transaction’s containing produced messages that they shouldn’t
-
Must start tx in MockProducer as well
-
Fixes example app tests - incorrectly testing wrong thing and MockProducer not configured to auto complete
-
Add missing revoke flow to MockConsumer wrapper
-
Add missing latch timeout check
-
Have massively parallel consumption processing without running hundreds or thousands of
-
Kafka consumer clients
-
topic partitions
without operational burden or harming the clusters performance
-
-
Efficient individual message acknowledgement system (without local or third system state) to massively reduce message replay upon failure
-
Per
key
concurrent processing, perpartition
and unordered message processing -
Offsets
committed correctly, in order, of only processed messages, regardless of concurrency level or retries -
Vert.x non-blocking library integration (HTTP currently)
-
Fair partition traversal
-
Zero~ dependencies (
Slf4j
andLombok
) for the core module -
Java 8 compatibility
-
Throttle control and broker liveliness management
-
Clean draining shutdown cycle