Class: God::CLI::Run
- Inherits:
-
Object
- Object
- God::CLI::Run
- Defined in:
- lib/god/cli/run.rb
Instance Method Summary collapse
- #attach ⇒ Object
- #default_run ⇒ Object
- #dispatch ⇒ Object
-
#initialize(options) ⇒ Run
constructor
A new instance of Run.
- #load_config(config) ⇒ Object
- #load_god_file(god_file) ⇒ Object
- #run_daemonized ⇒ Object
- #run_in_front ⇒ Object
- #setup_logging ⇒ Object
Constructor Details
#initialize(options) ⇒ Run
Returns a new instance of Run.
5 6 7 8 9 |
# File 'lib/god/cli/run.rb', line 5 def initialize() @options = dispatch end |
Instance Method Details
#attach ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/god/cli/run.rb', line 23 def attach process = System::Process.new(@options[:attach]) Thread.new do loop do unless process.exists? applog(nil, :info, "Going down because attached process #{@options[:attach]} exited") exit! end sleep 5 end end end |
#default_run ⇒ Object
36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/god/cli/run.rb', line 36 def default_run # make sure we have STDIN/STDOUT redirected immediately setup_logging # start attached pid watcher if necessary if @options[:attach] self.attach end if @options[:port] God.port = @options[:port] end if @options[:events] God::EventHandler.load end # set log level, defaults to WARN if @options[:log_level] God.log_level = @options[:log_level] else God.log_level = @options[:daemonize] ? :warn : :info end if @options[:config] unless File.exist?(@options[:config]) abort "File not found: #{@options[:config]}" end # start the event handler God::EventHandler.start if God::EventHandler.loaded? load_config @options[:config] end setup_logging end |
#dispatch ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 |
# File 'lib/god/cli/run.rb', line 11 def dispatch # have at_exit start god $run = true # run if @options[:daemonize] run_daemonized else run_in_front end end |
#load_config(config) ⇒ Object
144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 |
# File 'lib/god/cli/run.rb', line 144 def load_config(config) if File.directory? config files_loaded = false Dir[File.('**/*.god', config)].each do |god_file| files_loaded ||= load_god_file(File.(god_file)) end unless files_loaded abort "No files could be loaded" end else unless load_god_file(File.(config)) abort "File could not be loaded" end end end |
#load_god_file(god_file) ⇒ Object
160 161 162 163 164 165 166 167 168 169 170 171 |
# File 'lib/god/cli/run.rb', line 160 def load_god_file(god_file) load File.(god_file) rescue Exception => e if e.instance_of?(SystemExit) raise else puts "There was an error in #{god_file}" puts "\t" + e. puts "\t" + e.backtrace.join("\n\t") return false end end |
#run_daemonized ⇒ Object
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 |
# File 'lib/god/cli/run.rb', line 83 def run_daemonized # trap and ignore SIGHUP Signal.trap('HUP') {} pid = fork do begin require 'god' # set pid if requested if @options[:pid] # and as deamon God.pid = @options[:pid] end unless @options[:syslog] Logger.syslog = false end default_run unless God::EventHandler.loaded? puts puts "***********************************************************************" puts "*" puts "* Event conditions are not available for your installation of god." puts "* You may still use and write custom conditions using the poll system" puts "*" puts "***********************************************************************" puts end rescue => e puts e. puts e.backtrace.join("\n") abort "There was a fatal system error while starting god (see above)" end end if @options[:pid] File.open(@options[:pid], 'w') { |f| f.write pid } end ::Process.detach pid exit end |
#run_in_front ⇒ Object
73 74 75 76 77 78 79 80 81 |
# File 'lib/god/cli/run.rb', line 73 def run_in_front require 'god' if @options[:bleakhouse] BleakHouseDiagnostic.install end default_run end |
#setup_logging ⇒ Object
129 130 131 132 133 134 135 136 137 138 139 140 141 142 |
# File 'lib/god/cli/run.rb', line 129 def setup_logging log_file = God.log_file log_file = File.(@options[:log]) if @options[:log] log_file = "/dev/null" if !log_file && @options[:daemonize] if log_file puts "Sending output to log file: #{log_file}" unless @options[:daemonize] # reset file descriptors STDIN.reopen "/dev/null" STDOUT.reopen(log_file, "a") STDERR.reopen STDOUT STDOUT.sync = true end end |