public
Last active

Monit template files

  • Download Gist
redis.erb
HTML+ERB
1 2 3 4
check process redis
start program = "/usr/bin/redis-server /etc/redis/redis.conf"
stop program = "/usr/bin/redis-cli -p 6379 shutdown"
with pidfile /var/run/redis.pid
redis.rb
Ruby
1 2 3
# /config/initializers/redis.rb
 
$redis = Redis.new
sidekiq.erb
HTML+ERB
1 2 3 4
check process sidekiq with pidfile <%= sidekiq_pid %>
start program = "/etc/init.d/sidekiq_<%= application %> start"
stop program = "/etc/init.d/sidekiq_<%= application %> stop"
if totalmem is greater than 200 MB for 2 cycles then restart
unicorn.rb.erb
HTML+ERB
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
working_directory "<%= current_path %>"
pid "<%= unicorn_pid %>"
stderr_path "<%= unicorn_log %>"
stdout_path "<%= unicorn_log %>"
 
listen "/tmp/unicorn.<%= application %>.sock"
worker_processes <%= unicorn_workers %>
timeout 30
 
preload_app true
 
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
end
 
after_fork do |server, worker|
# https://github.com/redis/redis-rb/blob/master/examples/unicorn/unicorn.rb
# Redis.current.quit
 
# https://github.com/mperham/sidekiq/wiki/Problems-and-Troubleshooting
# Sidekiq.configure_client do |config|
# config.redis = { size: 1 }
# end
 
# Start up the database connection again in the worker
if defined?(ActiveRecord::Base)
ActiveRecord::Base.establish_connection
end
end

Please sign in to comment on this gist.

Something went wrong with that request. Please try again.