Comments (3)
Is this perhaps something thats only relevent when running InMemory and gets replaced when for example using ServiceBus perhaps? (If so, then it's much less of a concern - I am seeing this class in local testing with an InMemory setup currently)
from rebus.
This design came from back when Rebus was originally built, and back then it used MSMQ, which did not have an asynchronous receive API that was easy to work with.
Rebus simply starts a number of dedicated "worker threads" (default: 1), which it will then use to begin the receive operation. How many receive operations will then be determined by the "max parallelism" (default: 5), and if the transport supports truly async Task
-based receive, then message dispatch will continue on the thread pool.
TBH I've never tried to dive into the performance characteristics of this design beyond from a usage perspective, where it just seems that Rebus does not consume much memory, does not consume much CPU when running idle, seems to have a low latency when receiving messages, and seems to be well-behaved towards other things running in the same process and/or on the same machine.
If this is something that interests you, please feel free to tear it apart, if you can 😉
Oh, and please note: If it wasn't entirely clear, the "worker threads" are DEDICATED worker threads, which Rebus creates, and so it doesn't affect .NET's thread pool or anything else. And the threads are created when Rebus starts, and they're stopped again when Rebus shuts down, so once they're there, they will stay there until Rebus stops.
from rebus.
I found the docs saying that a TPL based approach is also provided and I think this makes a great deal of sense for transports that do support async receive, and it simplifies the concurrency setting by taking an option away :-)
https://github.com/rebus-org/Rebus/wiki/Workers-and-parallelism#tpl-based-workers
from rebus.
Related Issues (20)
- Empty session ID header added on retry HOT 1
- Outbox question HOT 1
- I am getting the error: Rebus.Exceptions.MessageCouldNotBeDispatchedToAnyHandlersException: type could not be dispatched to any handlers HOT 1
- How to mock MessageContext.Current in outgoing step? HOT 2
- Question about "Could not find existing saga data for message" HOT 7
- Release notes or migration guides for breaking changes when new major is released HOT 1
- Question: Manually acknowledge the message in RabbitMQ HOT 6
- Redis transport integration HOT 5
- Question: Kafka transport ? 😢 HOT 1
- FailFastException and 2nd level retries behaviour change between v7 and v8 HOT 8
- Configuration for web application (load balanced) with multiple subscribers HOT 2
- Spoof Rebus from Java, C++ etc. HOT 5
- Error handler not having access to the original exceptions HOT 7
- Issue when using both RetryStrategy and EnableEncryption, IFailed<message> handlers not called HOT 2
- Add additional TFM's so package dependencies can be optimised
- In net standard 2.1 Eliminate the dependency on System.Threading.AccessControl
- Outbox transaction always commits with second level retries enabled HOT 1
- OpenTelemetry Support HOT 1
- Could not get .NET type named during Deserialize HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
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.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from rebus.