2013-07-05 19:08:13 -04:00
|
|
|
require 'puma/runner'
|
|
|
|
|
|
|
|
module Puma
|
|
|
|
class Single < Runner
|
|
|
|
def stats
|
|
|
|
b = @server.backlog
|
|
|
|
r = @server.running
|
|
|
|
%Q!{ "backlog": #{b}, "running": #{r} }!
|
|
|
|
end
|
|
|
|
|
|
|
|
def restart
|
|
|
|
@server.begin_restart
|
|
|
|
end
|
|
|
|
|
|
|
|
def stop
|
|
|
|
@server.stop false
|
|
|
|
end
|
|
|
|
|
|
|
|
def halt
|
|
|
|
@server.halt
|
|
|
|
end
|
|
|
|
|
|
|
|
def stop_blocked
|
|
|
|
log "- Gracefully stopping, waiting for requests to finish"
|
2013-07-09 01:36:43 -04:00
|
|
|
@control.stop(true) if @control
|
2013-07-05 19:08:13 -04:00
|
|
|
@server.stop(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
def jruby_daemon?
|
|
|
|
daemon? and @cli.jruby?
|
|
|
|
end
|
|
|
|
|
|
|
|
def run
|
|
|
|
already_daemon = false
|
|
|
|
|
|
|
|
if jruby_daemon?
|
|
|
|
require 'puma/jruby_restart'
|
|
|
|
|
|
|
|
if JRubyRestart.daemon?
|
|
|
|
# load and bind before redirecting IO so errors show up on stdout/stderr
|
|
|
|
load_and_bind
|
|
|
|
end
|
|
|
|
|
|
|
|
already_daemon = JRubyRestart.daemon_init
|
|
|
|
end
|
|
|
|
|
2013-07-05 20:09:18 -04:00
|
|
|
output_header "single"
|
2013-07-05 19:08:13 -04:00
|
|
|
|
|
|
|
if jruby_daemon?
|
2013-08-13 19:05:51 -04:00
|
|
|
if already_daemon
|
|
|
|
JRubyRestart.perm_daemonize
|
|
|
|
else
|
2013-07-05 19:08:13 -04:00
|
|
|
pid = nil
|
|
|
|
|
|
|
|
Signal.trap "SIGUSR2" do
|
|
|
|
log "* Started new process #{pid} as daemon..."
|
2013-08-08 18:48:50 -04:00
|
|
|
|
|
|
|
# Must use exit! so we don't unwind and run the ensures
|
|
|
|
# that will be run by the new child (such as deleting the
|
|
|
|
# pidfile)
|
2013-08-21 01:25:25 -04:00
|
|
|
exit!(true)
|
2013-07-05 19:08:13 -04:00
|
|
|
end
|
|
|
|
|
2013-07-11 14:46:18 -04:00
|
|
|
Signal.trap "SIGCHLD" do
|
|
|
|
log "! Error starting new process as daemon, exitting"
|
|
|
|
exit 1
|
|
|
|
end
|
|
|
|
|
2013-07-05 19:53:52 -04:00
|
|
|
pid = @cli.jruby_daemon_start
|
2013-07-05 19:08:13 -04:00
|
|
|
sleep
|
|
|
|
end
|
|
|
|
else
|
|
|
|
load_and_bind
|
2013-07-06 00:13:29 -04:00
|
|
|
|
2013-07-05 20:09:18 -04:00
|
|
|
if daemon?
|
|
|
|
log "* Daemonizing..."
|
|
|
|
Process.daemon(true)
|
|
|
|
end
|
2013-07-05 19:08:13 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
@cli.write_state
|
|
|
|
|
2013-07-09 01:36:43 -04:00
|
|
|
start_control
|
|
|
|
|
2013-07-06 00:13:29 -04:00
|
|
|
@server = server = start_server
|
2013-07-05 19:08:13 -04:00
|
|
|
|
|
|
|
unless @options[:daemon]
|
|
|
|
log "Use Ctrl-C to stop"
|
|
|
|
end
|
|
|
|
|
|
|
|
redirect_io
|
|
|
|
|
2013-07-05 19:54:15 -04:00
|
|
|
@cli.events.fire_on_booted!
|
|
|
|
|
2013-07-05 19:08:13 -04:00
|
|
|
begin
|
|
|
|
server.run.join
|
|
|
|
rescue Interrupt
|
|
|
|
# Swallow it
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|