Class: InstanceAgent::Runner::Master

Inherits:
ProcessManager::Daemon::Master
  • Object
show all
Defined in:
lib/instance_agent/runner/master.rb

Constant Summary collapse

ChildTerminationMaxWaitTime =
80

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.child_classObject



17
18
19
# File 'lib/instance_agent/runner/master.rb', line 17

def self.child_class
  ::InstanceAgent::Runner::Child
end

.description(pid = $$) ⇒ Object



13
14
15
# File 'lib/instance_agent/runner/master.rb', line 13

def self.description(pid = $$)
  "master #{pid}"
end

.log_fileObject



37
38
39
# File 'lib/instance_agent/runner/master.rb', line 37

def self.log_file
  File.join(ProcessManager::Config.config[:log_dir], "#{ProcessManager::Config.config[:program_name]}.log")
end

.pid_descriptionObject



21
22
23
# File 'lib/instance_agent/runner/master.rb', line 21

def self.pid_description
  ProcessManager::Config.config[:program_name]
end

.pid_fileObject



41
42
43
# File 'lib/instance_agent/runner/master.rb', line 41

def self.pid_file
  File.join(ProcessManager::Config.config[:pid_dir], "#{ProcessManager::Config.config[:program_name]}.pid")
end

Instance Method Details

#kill_children(sig) ⇒ Object



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
# File 'lib/instance_agent/runner/master.rb', line 74

def kill_children(sig)
  children.each do |index, child_pid|
    begin
      Process.kill(sig, child_pid)
    rescue Errno::ESRCH
    end
  end
    
  begin
    Timeout.timeout(ChildTerminationMaxWaitTime) do
      children.each do |index, child_pid|
        begin
          Process.wait(child_pid)
        rescue Errno::ESRCH
        end
      end
    end
  rescue Timeout::Error
    children.each do |index, child_pid|
      if ProcessManager.process_running?(child_pid)
        puts "Stopping #{ProcessManager::Config.config[:program_name]} agent(#{pid}) but child(#{child_pid}) still processing."
        ProcessManager::Log.warn("Stopping #{ProcessManager::Config.config[:program_name]} agent(#{pid}) but child(#{child_pid}) is still processing.")
      end
    end
  end
end

#stopObject



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
# File 'lib/instance_agent/runner/master.rb', line 45

def stop
  if (pid = self.class.find_pid)
    puts "Stopping #{description(pid)}"
    ProcessManager::Log.info("Stopping #{description(pid)}")
    begin
      Process.kill('TERM', pid)
    rescue Errno::ESRCH
    end
    
    begin
      Timeout.timeout(ChildTerminationMaxWaitTime) do  
        loop do
          begin
            Process.kill(0, pid)
            sleep(1)
          rescue Errno::ESRCH
            break
          end
        end
      end
    rescue Timeout::Error
      puts "Child processes still running. Master going down."
      ProcessManager::Log.warn("Master process (#{pid}) going down before terminating child")
    end
  else
    puts "Nothing running that could be stopped"
  end
end

#validate_ssl_configObject



25
26
27
28
29
30
31
32
33
34
35
# File 'lib/instance_agent/runner/master.rb', line 25

def validate_ssl_config
  if !.instance_id.blank?
    region = .region
    request_helper = InstanceAgent::CodeDeployPlugin::RequestHelper.new(:deploy_control_client => InstanceAgent::CodeDeployPlugin::CodeDeployControl.new(:region => region))

    if (errors = request_helper.verify_clients_configuration)
      errors.each{|error| ProcessManager::Log.error("Stopping CodeDeploy agent. " + error)}
    end
    self.class.abort unless errors.empty?
  end
end