-
Notifications
You must be signed in to change notification settings - Fork 953
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
Allow identifier with multiple workers #1191
Comments
Why are you trying to do this? |
In order to better utilize a worker node, we would like to spawn as many workers as possible (until a CPU or memory limit is hit). Yes, I know that we can call the |
Why are you specifying an identifier? |
Because we have multiple nodes running More context for using identifiers can be found e.g. in #866. |
You are referencing a very old issue that had more than an identifier at play. Delayed Job automatically handles multiple nodes just fine except in rare non-standard scenarios. Are you not able to give each node a unique hostname? |
Thanks, that's a good question. I have checked in the DB and I see that jobs are locked as expected (with the identifier and node's hostname + PID): locked_by: "delayed_job.1685897776 host:ip-172-28-22-203.eu-west-1.compute.internal pid:2618", Ought to be unique enough. We have implemented identifiers back in January 2018. One-off jobs were fired multiple times back then, so adding identifiers helped. I do not have much information on why the locking mechanism did not work well back then. |
Setting my particular use case aside, what about the PR? Looks good? I don't see much harm with enabling it, especially since a Bash workaround is supported anyway:
|
Hello,
Using identifiers with multiple workers has been prevented for 14 years at least. Maybe it is time to reconsider it.
The PR #1190 loosens up that restriction and allows multiple identified job workers to be started with the following process name format:
Both fields are optional, so the default process name remains unchanged (
delayed_job
).The text was updated successfully, but these errors were encountered: