我有一个控制器,可以生成HTML、XML和CSV报告。用于这些报告的查询需要一分钟以上的时间才能返回结果。
在后台运行这些任务,然后将结果返回给用户的最佳方法是什么?我查过Backgroundrb了。还有没有更基本的东西可以满足我的需求?
发布于 2010-02-23 23:53:03
您可以考虑使用DelayedJob为您执行这些查询,并创建一个名为"NotificationQueue“的附加表。当作业(及其结果集)完成时,将结果集和执行该查询的人员的用户ID存储在NotificationQueue表中。然后,在每次页面加载时(如果您愿意,每15-20秒轮询一次),轮询该数据库并查看是否有任何已完成的查询。
DelayedJob真的很棒,因为您编写代码时,就好像不会是一个延迟的作业一样,只需更改代码以执行以下操作:
#Your method
Query.do_something(params)
#Change to
Query.send_later(:do_something, params)我们在工作中一直在使用它,它工作得很好。
https://stackoverflow.com/questions/2319454
复制相似问题