-
#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