Resqus: git://github.com/defunkt/resque.git
来自于railscasts
安装redis,并启动redis
sudo redis-server /etc/redis.conf
在项目中配置redis,在config/下新建resque.yml
defaults: &defaults
host: localhost
port: 6379
development:
<<: *defaults
test:
<<: *defaults
staging:
<<: *defaults
production:
<<: *defaults
在config/initializers/下新建resque.rb
rails_env = ENV['RAILS_ENV'] || 'development'
resque_config = YAML.load_file(rails_root + '/config/resque.yml')
Resque.redis = resque_config[rails_env]
在Rakefile中加入
require 'resque/tasks'
在rails的项目中加入resque,在Gemfile中加入gem
gem 'resque', :require => 'resque/server'
在项目的lib/task/下新建文件:resque.rake
require 'resqus/tasks' task "resque:setup" => :environment
在app下新建文件夹workers,并新建文件snipper_highlighter.rb
class SnippetHighlighter @queue = :snippets_queue def self.perform(snippet_id) snippet = Snippet.find(snippet_id) ......... end end
在需要异步任务的代码里加入类似代码
Resque.enqueue(SinppetHighlighter, snippet.id)
开启resque-web
resque-web
执行resque任务
rake resque:work QUEUE='*'
将resque-web绑定到项目中来,在routes.rb中加入
mount Resque::Server, :at => '/resque'
这样在项目中通过路由/resque就能访问到resque-web了,并可设置访问密码,在config/initializers中新建resque_auth.rb文件
Resque::Server.use(Rack::Auth::Basic) do |user, password| password == 'secret' end