-
Notifications
You must be signed in to change notification settings - Fork 186
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Question: is there any 'nats' alike queue-group possible now or in future? #233
Comments
Hi, it seems to me that we can't do this without logic on the publisher's side. For example, the publisher first publishes a message-question "who is ready to accept the message?". Then he listens to the responses and collects a list of responded subscribers. Then he randomly selects one and sends a message to him specifically. Maybe here we can add an intermediary publisher that will do this and the top-level publisher will only emit. |
Yes, I believe this is outside the scope of cote—the main reason is that I believe queues are inherently not well-suited for microservices “communication”, and is just a workload management system. If there’s a need to implement queue functionality as a workload management system on top of a communication mechanism (cote), then that should be on the client-side. Cote can support in building the communication blocks in this, and @dmetreeves’s recommendation isn’t far off than what I would say. |
Hi, thanks for the great library. I have now realized that there is an important missing point in my approach. If the publisher does not know in advance exactly how many subscribers he has, then how can he understand exactly when in time to finish listening to messages, so that he can then choose one at random? To do this, we will have to use the "setTimeout" function inside the publisher, or additionally constantly ping the listeners? How would you make a communication system of this type (when only one random subscriber out of many has to process a message from the publisher)? Thanks! |
Ok. The following algorithm should work:
|
Hi, I am impressed and eager to test out cote because of your mesh-like discovery features.
The only feature I am missing (or not might have found) is something called "queue-groups" in nats:
https://github.com/nats-io/nats.js#queue-groups
Say you have a publisher emitting an event. And you have some worker-groups running multiple processes for different concerns. Example:
A published event (or might be a request?) should be processed by only 1 A worker + only 1 B worker. And of course, the publisher won't know anything about groups or workers, just emitting "something.done" to anyone interested.
The text was updated successfully, but these errors were encountered: