module RocketJob # Information about a server currently working on a job class ActiveWorker # When this server started working on this job / slice attr_accessor :started_at attr_accessor :name, :job # Returns [Hash] hash of all servers sorted by name # and what they are currently working on. # Returns {} if no servers are currently busy doing any work # # Parameters # server_name: [String] # Only jobs running on the specified server def self.all(server_name = nil) servers = [] # Need paused, failed or aborted since servers may still be working on active slices query = RocketJob::Job.where(:state.in => [:running, :paused, :failed, :aborted]) query = query.where(worker_name: /\A#{server_name}/) if server_name query.each do |job| servers += job.rocket_job_active_workers end servers end # Requeues all jobs for which the workers have disappeared def self.requeue_zombies all.each do |active_worker| next if !active_worker.zombie? || !active_worker.job.may_requeue? active_worker.job.requeue!(active_worker.server_name) end end def initialize(name, started_at, job) @name = name @started_at = started_at @job = job end # Duration in human readable form def duration RocketJob.seconds_as_duration(duration_s) end # Number of seconds this server has been working on this job / slice def duration_s Time.now - (started_at || Time.now) end # Returns [String] the name of the server running this worker def server_name if match = name.match(/(.*:.*):.*/) match[1] else name end end def server @server ||= RocketJob::Server.where(name: server_name).first end # The server on which this worker was running is no longer running def zombie? server.nil? end def name=(name) @server = nil @name = name end end end