Comments (3)
In my perspective when the producer is faster than the consumer, the buffer will eventually be filled fullly and the only choice is to drop messages. Anyway, just to start a single goroutine to receive messages from NATS and put them to a channel shall solve this. Other than that, we could create a thread pool like panjf2000/ants
and then submit consumer tasks to it. This gives the ability to dynamically adjust goroutine count.
Not quite sure whether those work. Not familiar with NATS. :D
from backend-next.
Yes. However the correct behavior is for NATS JetStream to store a reasonable amount of buffer when a slow-consumer is encountered, due to the fact we are not expecting those data to be temporal sequential (delivered in-order). I'll see if there's a way to mitigate this issue as I believe there's some sort of configuration items I could tweak to make it perform better lol.
from backend-next.
wontfix: NATS will not actually drop the message due to the fact we haven't ACKed it, so NATS will send us the "dropped" message just simply later than what we'd expected.
from backend-next.
Related Issues (20)
- Dependency Dashboard
- Drop Matrix and Trend Calc Job Optimization
- LiveHouse Implementation
- Arkplanner returns with only "Operation Barrenland Supplies" HOT 3
- The Adoption of T-test Instead of Z-test Might Improve the Accuracy HOT 1
- `/PenguinStats/api/v2/recognition/defects/report/init` 可能需要改善 HOT 2
- Typo in item name HOT 1
- Failed to do advanced query if `interval` is specified and `endTime` is not specified HOT 2
- Add Recognition WASM & Assets Version Report Support HOT 1
- Data Inconsistency & Unexpected Structure Monitoring
- Shorten Cache TTL
- Improve GitHub Community Experience
- Compose `CONTRIBUTING.md`
- `/PenguinStats/api/v2/result/advanced` not overriding response `startTime`
- Use more precise annotations on reliability != 0 situations
- Ignore items that are not presenting in DB rather than throwing an error
- Cronjob-based Automatic Report Rejections based on Dynamic Rules
- Report Verifier should not Short Circuit on Looping Reports HOT 1
- SemVerPrefixed Validation Rule should be Enforced to Always Prefixed
- Change Snowflake to Actual Node ID 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 backend-next.