disruptor
disruptor copied to clipboard
High Performance Inter-Thread Messaging Library
ProcessingSequenceBarrier.java ```java public long waitFor(final long sequence) throws AlertException, InterruptedException, TimeoutException { checkAlert(); long availableSequence = waitStrategy.waitFor(sequence, cursorSequence, dependentSequence, this); if (availableSequence < sequence) { return availableSequence; } return sequencer.getHighestPublishedSequence(sequence,...
**Describe the bug** With many producers and a blocking wait strategy, `SequenceBarrier.waitForSequence(nextSequence)` can return a value less than its input. Specifically, it can return `nextSequence - 1`. **To Reproduce** Run...
### I used BlockingWaitStrategy in my code,it makes my project use CPU 100% I use it for exception alert.Our system tps is not high,Fewer exceptions. As you know,I didn't use...
https://github.com/LMAX-Exchange/disruptor/blob/109e2881fa421ceac31c7aabc3b96bfd2a94587d/src/main/java/com/lmax/disruptor/SingleProducerSequencer.java#L102 What case will run this code “cachedGatingSequence > current” ? Could Consumer's sequence be more than Producer's sequence ? But this case can be possible ?
**Desktop (please complete the following information):** - OS: [win10] - Version [e.g. 3.4.4] - JVM Version [1.8.0_221] **Additional context** data:image/s3,"s3://crabby-images/73d49/73d4950b9563bb3caeab75d9c3bd8e46bfbf2cd4" alt="image" data:image/s3,"s3://crabby-images/52945/52945fc7927be2fea61ac6bb955522bacde29bff" alt="image" data:image/s3,"s3://crabby-images/b4d69/b4d6902d0280c5f4a57d0a7d2bcb2db52aa650eb" alt="image" data:image/s3,"s3://crabby-images/6585b/6585b31bbf0b2ba071c017262e3ec0e7b58675eb" alt="image" Can I use Disruptor like this, and...
In the next(n) method we used `long wrapPoint = nextSequence - bufferSize;wrapPoint > cachedGatingSequence` in determining whether a wrap occurred or not.For example, in the following figure: Let's say we've...
Fix the issue where messages are lost if a consumer that is processing an event is killed.
Description In version 3.3.6, dynamically removing a consumer thread that is currently processing a message can result in message loss. This issue occurs because the consumer thread might be terminated...
https://lmax-exchange.github.io/disruptor/disruptor.html data:image/s3,"s3://crabby-images/f6c1a/f6c1a12d79fac258d40a7c65a5760fa09c142782" alt="image" Ooops. ---- Also, could you a bit extend the tech paper on cache contention and on the multiple (and variable number) both consumers and producers, and why you...