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
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
|
module Oxidized
class CLI
require 'slop'
require 'oxidized'
def run
check_pid
Process.daemon if @opts[:daemonize]
write_pid
begin
Oxidized.logger.info "Oxidized starting, running as pid #{$$}"
Oxidized.new
rescue => error
crash error
raise
end
end
private
def initialize
_args, @opts = parse_opts
Config.load(@opts)
Oxidized.setup_logger
@pidfile = File.expand_path(Oxidized.config.pid)
end
def crash error
Oxidized.logger.fatal "Oxidized crashed, crashfile written in #{Config::Crash}"
open Config::Crash, 'w' do |file|
file.puts '-' * 50
file.puts Time.now.utc
file.puts error.message + ' [' + error.class.to_s + ']'
file.puts '-' * 50
file.puts error.backtrace
file.puts '-' * 50
end
end
def parse_opts
opts = Slop.new(:help => true) do
on 'd', 'debug', 'turn on debugging'
on 'daemonize', 'Daemonize/fork the process'
on 'v', 'version', 'show version' do
puts Oxidized::VERSION_FULL
Kernel.exit
end
end
[opts.parse!, opts]
end
def pidfile
@pidfile
end
def pidfile?
!!pidfile
end
def write_pid
if pidfile?
begin
File.open(pidfile, ::File::CREAT | ::File::EXCL | ::File::WRONLY) { |f| f.write("#{Process.pid}") }
at_exit { File.delete(pidfile) if File.exists?(pidfile) }
rescue Errno::EEXIST
check_pid
retry
end
end
end
def check_pid
if pidfile?
case pid_status(pidfile)
when :running, :not_owned
puts "A server is already running. Check #{pidfile}"
exit(1)
when :dead
File.delete(pidfile)
end
end
end
def pid_status(pidfile)
return :exited unless File.exists?(pidfile)
pid = ::File.read(pidfile).to_i
return :dead if pid == 0
Process.kill(0, pid)
:running
rescue Errno::ESRCH
:dead
rescue Errno::EPERM
:not_owned
end
end
end
|