我收到ActiveRecord::StatementInvalid (PG::Error: SSL error: decryption failed or bad record mac
错误,因此我按照guide about deploying Unicorn to Heroku进行操作,似乎已修复错误。但是,在caveats下,它会显示如何为此类设置配置Resque
- 我是否必须使用Sidekiq
执行类似操作?
Heroku的示例代码:
before_fork do |server, worker|
...
# If you are using Redis but not Resque, change this
if defined?(Resque)
Resque.redis.quit
Rails.logger.info('Disconnected from Redis')
end
end
after_fork do |server, worker|
...
# If you are using Redis but not Resque, change this
if defined?(Resque)
Resque.redis = ENV['REDIS_URI']
Rails.logger.info('Connected to Redis')
end
end
这是我目前设置的内容:
配置/ unicorn.rb
worker_processes 2
timeout 30
preload_app true
before_fork do |server, worker|
Signal.trap 'TERM' do
puts 'Unicorn master intercepting TERM and sending myself QUIT instead'
Process.kill 'QUIT', Process.pid
end
defined?(ActiveRecord::Base) and ActiveRecord::Base.connection.disconnect!
end
after_fork do |server, worker|
Signal.trap 'TERM' do
puts 'Unicorn worker intercepting TERM and doing nothing. Wait for master to send QUIT'
end
defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection
end
配置/初始化/ sidekiq.rb
require 'sidekiq'
Sidekiq.configure_client do |config|
config.redis = { :size => 1 }
end
Sidekiq.configure_server do |config|
config.redis = { :size => 6 }
end
Procfile
web: bundle exec unicorn -p $PORT -E $RACK_ENV -c ./config/unicorn.rb
worker: bundle exec sidekiq -e production -c 4
答案 0 :(得分:17)
自sidekiq版本2.9.0起,unicorn / passenger after_fork
无需配置。
以下是提及问题的release notes for version 2.9.0。
这是解决分叉连接的resolved issue。
最后,这是一个comment from the maintainer,确认不再需要after_fork
中的配置。
答案 1 :(得分:6)
这就是我所拥有的并且有效:
配置/ unicorn.rb
worker_processes Integer(ENV["WEB_CONCURRENCY"] || 5)
timeout 15
preload_app true
before_fork do |server, worker|
Signal.trap 'TERM' do
puts 'Unicorn master intercepting TERM and sending myself QUIT instead'
Process.kill 'QUIT', Process.pid
end
defined?(ActiveRecord::Base) and ActiveRecord::Base.connection.disconnect!
end
after_fork do |server, worker|
Signal.trap 'TERM' do
puts 'Unicorn worker intercepting TERM and doing nothing. Wait for master to send QUIT'
end
defined?(ActiveRecord::Base) and ActiveRecord::Base.establish_connection
Sidekiq.configure_client do |config|
config.redis = { size: 1, namespace: 'sidekiq' }
end
end
配置/初始化/ sidekiq.rb
ENV["REDIS_URL"] ||= "redis://localhost:6379"
Sidekiq.configure_server do |config|
config.redis = { url: ENV["REDIS_URL"], namespace: 'sidekiq' }
end
unless Rails.env.production?
Sidekiq.configure_client do |config|
config.redis = { url: ENV["REDIS_URL"], namespace: 'sidekiq' }
end
end
注意:我在开发时使用thin
,在heroku上使用unicorn
。