有没有办法可以看到有多少(甚至可以检查每个工作?)队列中还有剩余的工作?
经过一些挖掘source code这里是我发现的:
ActiveJob::QueueAdapters::AsyncAdapter
使用Concurrent Ruby线程池来安排和执行作业。
在配置中初始化适配器时,传递执行程序选项,而后者恰好是initialize
类的Concurrent::ThreadPoolExecutor
方法的参数。
创建的Concurrent::ThreadPoolExecutor
类实例有这样的方法,如:
queue_length
- 等待执行的队列中的任务数。scheduled_task_count
- 自构建以来计划在池上执行的任务数。也就是说,我认为沿着这些方向应该为你做的事情:
ActiveJob::Base
.queue_adapter
.instance_variable_get(:@scheduler)
.instance_variable_get(:@async_executor)
.public_send(:queue_length)
以上做了以下事项:
@scheduler
,指向Concurrent::ThreadPoolExecutor
的实例(Scheduler
类的实例变量 - @async_executor
)queue_length
,scheduled_task_count
和others)虽然我没有测试它,所以一定要仔细检查拼写错误。