-
Notifications
You must be signed in to change notification settings - Fork 151
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
Send event / message to running Worker? #370
Comments
I guess it was the second part of this PR that was never implemented? :( #210 |
Thanks for your suggestion Michael. Yes there was a start with something like this in #210, but we still have to think through a good API for this. Help would be welcome! |
Hm. Just spitballing here... how about a new callback, similar to on() events. Something like let executionId: number | undefined;
pool.exec('eventExample', [], {
onExecutionStart: (id) => {
executionId = id;
},
on: function (payload) {
//...
},
});
...
if (executionId) {
pool.getWorkerInstance(executionId).emit('Take this!', {data: {...}});
} |
Yes that could work, though it involves an indirect solution via an identifier. How about extending the returned Promise-like instance: const handler = pool.exec('fibonacci', [10], {
on: function (payload) { ... }
}
// the returned promise-like `handler` actually is an extended version of Promise,
// having methods .then(callback), .catch(callback), .cancel(), .timeout(delay), and .emit(payload)
promise.emit('Take this!')
const result = await handler To prevent confusion, we should maybe rename |
That'd be much nicer of course! Also, it'd be nice if the messages would be queued up as well, in case the worker has not started yet (and alternatively, the promise should also return the current state of the task (queued, running, finished,...) so messages don't get lost) Adding this would make the pool so much more useful for controlling long running tasks! |
Yes, it will be nice to be able to have two way messaging between the main process and the worker. I'm not sure if it is possible to queue messages upfront: upfront you do not know at which worker a task will be assigned, only as soon as the task started you can send something to the worker where the task is running I think? Maybe you can share your use-case to better understand what a good API would be to cater for it? |
It'd be enough if the promise returned the state so that only in case it is running, a message could be sent.
The use case here is to run a long running task, which in itself is a workflow of multiple steps. These could take a while, so on the one hand we need to be able to timeout and cancel the task (which ideally requires some extra steps for a clean shutdown, other than just killing the task), and on the other hand we'd like to trigger actions on the running task as well (like adding a new step while it is running). It's all rather convoluted, tbh., but it requires a channel back into the worker, in any case :) |
Thanks. Makes sense. I think the the |
Sounds like a plan! Let me know if I can help out somehow. |
I'm not planning on implementing this myself, so if it is important to you or someone else have to jump in. |
I've created a PR with a relatively simple change to let the parent send messages to the worker instances parallel to the current execution. |
The backchannel from the worker back to the main thread via emit works fine, but are there ports set up the other way around (sending a message into the worker?)
Reason: I need to send updated data to a running process inside a worker.
The text was updated successfully, but these errors were encountered: