Git Product home page Git Product logo

Comments (3)

akarnokd avatar akarnokd commented on June 20, 2024
  1. Is your publishSubjectController serialized? Concurrent onNext access can lead to hangs or leaks.
  2. groupBy may hold open groups longer than anticipated, especially if the source has some form of rolling-grouping.
  3. Calling subscribe in forEach is a code smell as it breaks the chain. That can also cause leaks as those are no longer part of the same sequence to be automatically cleaned up.

from rxjava.

sr1996-glitch avatar sr1996-glitch commented on June 20, 2024

@akarnokd Thank you for quick reply.

  1. Its not serialized. Mainly because of high throughput requirement (and like I mentioned, this code worked well until very recently - maybe broken now due to increased load). I was able to simulate hang due to non-serialized publishsubject (under a much higher load and thread count), but it does not create consumer buffer bloating.

  2. There is no rolling-grouping. The incoming data can belong to 1 of 4 groups/topics (with a fairly similar probability). But, even then, are grouped elements cached in consumer buffer ?

  3. Point taken. I ll move the buffering+filtration to a flatmap.

from rxjava.

akarnokd avatar akarnokd commented on June 20, 2024

If you call onNext concurrently, you must serialize the subject.

toFlowable(BackpressureStrategy.BUFFER) has an unbounded buffer so if you can't drain it fast enough in downstream operators, it can lead to buffer bloat on its own. You'll have to rethink the dataflow, to use Flowables and some form of bounded data generation.

from rxjava.

Related Issues (20)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.