Class: PerfectQueue::Supervisor

Inherits:
Object
  • Object
show all
Defined in:
lib/perfectqueue/supervisor.rb

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(runner, config = nil, &block) ⇒ Supervisor

Returns a new instance of Supervisor.



26
27
28
29
30
31
32
33
34
# File 'lib/perfectqueue/supervisor.rb', line 26

def initialize(runner, config=nil, &block)
  # initial logger
  STDERR.sync = true
  @log = DaemonsLogger.new(STDERR)

  @runner = runner
  block = Proc.new { config } if config
  @config_load_proc = block
end

Class Method Details

.run(runner, config = nil, &block) ⇒ Object



22
23
24
# File 'lib/perfectqueue/supervisor.rb', line 22

def self.run(runner, config=nil, &block)
  new(runner, config, &block).run
end

Instance Method Details

#logrotatedObject



91
92
93
94
95
96
# File 'lib/perfectqueue/supervisor.rb', line 91

def logrotated
  @log.info "reopen a log file"
  @engine.logrotated
  @log.reopen!
  return true
end

#replace(immediate, command = [$0]+ARGV) ⇒ Object



79
80
81
82
83
84
85
86
87
88
89
# File 'lib/perfectqueue/supervisor.rb', line 79

def replace(immediate, command=[$0]+ARGV)
  @log.info immediate ? "Received immediate binary replace" : "Received graceful binary replace"
  begin
    @engine.replace(immediate, command)
  rescue
    @log.error "failed to replace: #{$!}"
    $!.backtrace.each {|bt| @log.warn "\t#{bt}" }
    return false
  end
  return true
end

#restart(immediate) ⇒ Object



67
68
69
70
71
72
73
74
75
76
77
# File 'lib/perfectqueue/supervisor.rb', line 67

def restart(immediate)
  @log.info immediate ? "Received immediate restart" : "Received graceful restart"
  begin
    @engine.restart(immediate, load_config)
  rescue
    @log.error "failed to restart: #{$!}"
    $!.backtrace.each {|bt| @log.warn "\t#{bt}" }
    return false
  end
  return true
end

#runObject



36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/perfectqueue/supervisor.rb', line 36

def run
  @log.info "PerfectQueue #{VERSION}"

  install_signal_handlers do
    @engine = Engine.new(@runner, load_config)
    begin
      @engine.run
    ensure
      @engine.shutdown(true)
    end
  end

  return nil
rescue
  @log.error "#{$!.class}: #{$!}"
  $!.backtrace.each {|x| @log.warn "\t#{x}" }
  return nil
end

#stop(immediate) ⇒ Object



55
56
57
58
59
60
61
62
63
64
65
# File 'lib/perfectqueue/supervisor.rb', line 55

def stop(immediate)
  @log.info immediate ? "Received immediate stop" : "Received graceful stop"
  begin
    @engine.stop(immediate) if @engine
  rescue
    @log.error "failed to stop: #{$!}"
    $!.backtrace.each {|bt| @log.warn "\t#{bt}" }
    return false
  end
  return true
end