-
-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Run queue tasks continuously #6062
Comments
The work-around is to bootstrap Drupal with each queue run, which isn't the worst, but I can put |
Cron as long running task sounds weird. Cron is meant for scheduled tasks. If you have a need to constantly process some large data, i.e. import products from external sources it's better to create a worker which could be an ordinary Drush command. Furthermore, even for scheduled custom tasks I would not mess with hook_cron but create a separate Drush command and put it to crontab like follows.
|
Ah that's right, I forget that modules can run tasks directly on cron run so maybe just having a long-running queue runner is actually what I want. |
@Chi-teck I updated the description, I hope this is helpful. it's honestly probably just an option on the existing command tbh |
I was tinkering with using (Advanced) Queue API for running server side commands. I thought there was a daemon! FWIW... This is how Aegir does it, with a Drush 8 command "hosting-queued": https://git.drupalcode.org/project/hosting/-/blob/7.x-3.x/queued/hosting_queued.drush.inc?ref_type=heads#L52-214 Would this be useful? https://github.com/mac-cain13/daemonizable-command Gonna look into this... |
I implemented something similar as a command some time ago. However, I don't currently use it. https://github.com/ueberbit/drush_queue_daemon |
Not sure if this module I've built some time ago could help https://www.drupal.org/project/recurring_task |
@webflo I liked your implementation, and I've tested it on my machine. If you don't mind explaining, why have you stopped to use that solution? |
@pierreabreup I no longer work for the client. But I think the code is still in use. I had no problems with it. I would use it again. |
I also built a lightweight (doesn't bootstrap Drupal unless necessary) queue runner that's currently running on multiple production sites: https://gist.github.com/DieterHolvoet/2ea792445f3498278e82221ab198288e |
@DieterHolvoet I suspect this eats 100% of CPU. while ($item = $queue->claimItem()) It needs some sleep on each iteration. |
Why's that? |
Never mind. It'll claims items unless the queue is empty. However, I think it'll not much better than |
Also restarting a process once a second could eat some resources. |
@DieterHolvoet why not just put |
To prevent memory leaks, or just memory piling up in general through e.g. static (entity) caches. Drupal so far isn't really optimized to be kept running for a long time, right? I'm not sure what is more performant, I'm also not saying my solution is the best one. All I can say is that it hasn't blown up any servers so far :) Would be interesting to compare the impact of different kinds of solutions. |
I would say it's pretty good with it. Typically, memory leaks because developers do not care about it. For instance, for static entity cache the |
To summarize PHP does not leak at all, at least in latest versions. Leaks mostly caused by custom code. However, small leaks like a few kB per day I would not even bother to debug. For the reference, a simple Drush command that does nothing consumes about 70 MB itself. Note that systemd is apparently does not have a way to gracefully restart a service when it exceed the configured memory limit. However, there are other process managers that do have have such an option. For instance, RoadRunner and Supervisord (via plugin). |
@DieterHolvoet that may happen with your current implementation as well. Memory does not leak when a process is idle. It will likely leak when it does something (i.e. |
Turns out you're right, this has been what's slowing down my server. Thanks for pointing that out. I'm going to look into the alternatives. |
I have a suggestion for a way to solve this problem in a generic way, that could be added to Drush core: add a I also want to suggest to add a I also want to suggest to add a @weitzman what do you think, is this something you would agree to add to Drush core? I think it's a good idea, except for the |
I don't see much value in a command that runs different queues. That's a bit different from what we have been discussing here. As for a daemon, see the command that webflo linked. Would that work? I'm not too inclined to put that in core drush but if we had a queue maintainer I would consider it. We should look into the revolt lib that Drupal core adopted https://www.drupal.org/project/drupal/issues/3394423 |
Ah, you're right, I didn't notice the issue is talking about processing a single queue. I guess that makes a
That one restarts every X seconds. With my proposal, there would be more control on how often the process is restarted.To keep it running until a certain level of memory usage is reached seems ideal to me. Also, it introduces a dependency on ReactPHP and I don't really see the added value of that here. My proposed implementation would be a lot simpler. What do you think about the proposed
I personally have very little experience and even understanding of this kind of async PHP. I feel like we're still far away from being able to use this in Drupal, so maybe for now we could focus on something simpler that also gets the job done? I do think it's something interesting to take a look at in the future though. |
I would be interested in that. I work a lot with queues when doing project work for my agency, so I'm invested in improving those commands + it's not like the field commands take up that much of my time :) |
I started a proof of concept PR for |
based on @webflo solution, I've created https://github.com/pierreabreup/drush-background-queue. I'm using it in my company inside a Kubernetes pod and it works fine for now. |
I also created a module with the queue:run-all command initially proposed in #6204: https://www.drupal.org/project/drush_queue_run_all |
Is your feature request related to a problem? Please describe.
We use Drupal's Queue feature to handle background tasks. However, many of these tasks are time sensitive and need to be executed in the background as soon as possible.
Drush doesn't provide a way to run a specific queue as a daemon, it can only be invoked on a schedule.
Describe the solution you'd like
I would really like a way to run Drupal queue as a long running task in the foreground. Then I can use systemd, docker, or k8s to keep it running.
Maybe a
queue:watch
command that is like:drush/src/Commands/core/QueueCommands.php
Lines 60 to 113 in 151b704
but that is running in an infinite loop (with a
usleep()
?) until the time limit or item limit is reached? Basically, it should keep running even if there are zero items in the queue right now.It might be nice to also limit the number of iterations by the amount of memory (i.e.
memory_get_usage()
) which would allow the script to be kept alive for as long as possible.Describe alternatives you've considered
drush queue:run
, but then we are doing the work to bootstrap Drupal and connect to the database on every iteration.Related:
Additional context
N/A
The text was updated successfully, but these errors were encountered: