Skip to content

Instantly share code, notes, and snippets.

@michaeldever
Last active December 5, 2017 16:58
Show Gist options
  • Save michaeldever/b6a0702035cdcfcd57951bfb24f7d75d to your computer and use it in GitHub Desktop.
Save michaeldever/b6a0702035cdcfcd57951bfb24f7d75d to your computer and use it in GitHub Desktop.
Daemon Logging Fix
#!/usr/bin/env ruby
ENV['RAILS_ENV'] ||= 'development'
require_relative '../config/environment'
def files_to_reopen
@files_to_reopen ||= []
end
def collect_open_files
# NOTE: Logging fix for daemons under Rails
ObjectSpace.each_object(File) do |file|
files_to_reopen << file unless file.closed?
end
end
def reopen_initial_files
# NOTE: Logging fix for daemons under Rails
files_to_reopen.each do |file|
file.reopen file.path, 'a+'
file.sync = true
end
end
collect_open_files
Daemons.run_proc('rabbit_mq', multiple: false, backtrace: true, log_output: true) do
begin
reopen_initial_files
rescue StandardError => e
puts e.message
puts e.backtrace
end
end
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment