我有一个在生产中使用 apache + 乘客运行的应用程序。目前,我在初始化程序中初始化 rufus 调度程序,并在该初始化程序中注册从数据库读取的作业。apache/passenger 的工作方式是它创建应用程序的多个进程/实例,这会导致调度程序被多次初始化并会调度重复的作业。
实现这个以使调度程序成为单例对象的正确方法是什么?
我有一个在生产中使用 apache + 乘客运行的应用程序。目前,我在初始化程序中初始化 rufus 调度程序,并在该初始化程序中注册从数据库读取的作业。apache/passenger 的工作方式是它创建应用程序的多个进程/实例,这会导致调度程序被多次初始化并会调度重复的作业。
实现这个以使调度程序成为单例对象的正确方法是什么?
您可能希望将 Rufus Scheduler 实现为应用程序之外的单独工作进程。
我不会将它作为初始化程序,而是实现一个启动它的 Rake 任务。
# Rakefile
desc "Starts the Scheduler worker"
task :scheduler do
require 'path/to/your/scheduler/file'
scheduler.join
end
然后只需运行rake scheduler
以在后台启动它。
奖励:由于您的应用程序现在需要并排的 2 个进程,因此请使用 Foreman 来管理您的应用程序的多个进程。您可以通过创建一个名为的文件来做到这一点Procfile
:
# Procfile
web: thin start -p 4242
scheduler: rake scheduler
然后用 Foreman 启动你的应用程序:(一定gem install foreman
要先)
$ foreman start
这将同时调用两个进程。