我使用unicorn网络服务器在heroku上设置了一个应用程序。 我的数据库是在外部服务器上设置的(不是在heroku上)。我已根据需要配置了DATABASE_URL。 当我运行heroku控制台时,我能够在服务器上成功运行查询。 但是,当我在启动unicorn之后转到URL时,我收到此错误:
2014-03-14T01:44:53.820853+00:00 app[web.1]: ActiveRecord::StatementInvalid (PG::ConnectionBad: connection is closed: SELECT a.attname, format_type(a.atttypid, a.atttypmod),
2014-03-14T01:44:53.820853+00:00 app[web.1]: pg_get_expr(d.adbin, d.adrelid), a.attnotnull, a.atttypid, a.atttypmod
2014-03-14T01:44:53.820853+00:00 app[web.1]: FROM pg_attribute a LEFT JOIN pg_attrdef d
2014-03-14T01:44:53.820853+00:00 app[web.1]: ON a.attrelid = d.adrelid AND a.attnum = d.adnum
2014-03-14T01:44:53.820853+00:00 app[web.1]: WHERE a.attrelid = '"currencies"'::regclass
2014-03-14T01:44:53.820853+00:00 app[web.1]: AND a.attnum > 0 AND NOT a.attisdropped
2014-03-14T01:44:53.820853+00:00 app[web.1]: ORDER BY a.attnum
2014-03-14T01:44:53.820853+00:00 app[web.1]: ):
2014-03-14T01:44:53.820853+00:00 app[web.1]: app/controllers/search_controller.rb:5:in `index'
我按照说明配置了它。这是我的独角兽配置。
worker_processes Integer(ENV["WEB_CONCURRENCY"] || 2)
timeout 25
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
if defined?(ActiveRecord::Base)
ActiveRecord::Base.connection.disconnect!
puts 'Unicorn disconnected from database'
end
# 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|
Signal.trap 'TERM' do
puts 'Unicorn worker intercepting TERM and doing nothing. Wait for master to send QUIT'
end
if defined?(ActiveRecord::Base)
config = Rails.application.config.database_configuration[Rails.env]
config['reaping_frequency'] = ENV['DB_REAP_FREQ'] || 10
config['pool'] = ENV['DB_POOL'] || 2
ActiveRecord::Base.establish_connection(config)
puts 'Unicorn connected to database'
end
# If you are using Redis but not Resque, change this
if defined?(Resque)
Resque.redis = $redis
Rails.logger.info('Connected to Redis')
end
end
为什么即使连接成功后连接也会关闭? (我在日志中看到Unicorn connected to database
。
答案 0 :(得分:0)
在Rails 3 + Resque中,我不得不添加:
Resque.after_fork do |job|
ActiveRecord::Base.verify_active_connections!
end
我打赌类似的东西对你有用。池中的连接超时;他们必须被清除。虽然Rails 4有所变化,但请参阅此处https://github.com/socialcast/resque-ensure-connected/issues/3