Sha256: 40a8b3ab81cd394976107d5a894ba51dac22e8543b1014ac72b1af1c98ae02d6

Contents?: true

Size: 1.23 KB

Versions: 5

Compression:

Stored size: 1.23 KB

Contents

working_directory "<%= current_path %>"
pid "<%= fetch(:unicorn_pid) %>"
stdout_path "<%= unicorn_log_file %>"
stderr_path "<%= unicorn_error_log_file %>"

<% if fetch(:unicorn_use_tcp) %>
listen <%= fetch(:unicorn_tcp_listen_port) %>
<% else %>
listen "/tmp/unicorn.<%= fetch(:nginx_config_name) %>.sock"
<% end %>

worker_processes <%= fetch(:unicorn_workers) %>
timeout 30

preload_app true

before_exec do |server|
  ENV["BUNDLE_GEMFILE"] = "<%= current_path %>/Gemfile"
end

before_fork do |server, worker|
  # Disconnect since the database connection will not carry over
  if defined? ActiveRecord::Base
    ActiveRecord::Base.connection.disconnect!
  end

  # Quit the old unicorn process
  old_pid = "#{server.config[:pid]}.oldbin"
  if File.exists?(old_pid) && server.pid != old_pid
    begin
      Process.kill("QUIT", File.read(old_pid).to_i)
    rescue Errno::ENOENT, Errno::ESRCH
      # someone else did our job for us
    end
  end

  if defined?(Resque)
    Resque.redis.quit
  end

  sleep 1
end

after_fork do |server, worker|
  # Start up the database connection again in the worker
  if defined?(ActiveRecord::Base)
    ActiveRecord::Base.establish_connection
  end

  if defined?(Resque)
    Resque.redis = 'localhost:6379'
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
capistrano-unicorn-nginx-3.2.0 lib/generators/capistrano/unicorn_nginx/templates/unicorn.rb.erb
capistrano-unicorn-nginx-3.1.2 lib/generators/capistrano/unicorn_nginx/templates/unicorn.rb.erb
capistrano-unicorn-nginx-3.1.1 lib/generators/capistrano/unicorn_nginx/templates/unicorn.rb.erb
capistrano-unicorn-nginx-3.1.0 lib/generators/capistrano/unicorn_nginx/templates/unicorn.rb.erb
capistrano-unicorn-nginx-3.0.0 lib/generators/capistrano/unicorn_nginx/templates/unicorn.rb.erb