|  |  | @ -430,7 +430,7 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  |             raise StopRequested() |  |  |  |             raise StopRequested() | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     def handle_warm_shutdown_request(self): |  |  |  |     def handle_warm_shutdown_request(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.log.warning('Warm shut down requested') |  |  |  |         self.log.info('Warm shut down requested') | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     def check_for_suspension(self, burst): |  |  |  |     def check_for_suspension(self, burst): | 
			
		
	
		
		
			
				
					
					|  |  |  |         """Check to see if workers have been suspended by `rq suspend`""" |  |  |  |         """Check to see if workers have been suspended by `rq suspend`""" | 
			
		
	
	
		
		
			
				
					|  |  | @ -469,7 +469,7 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  |         self._install_signal_handlers() |  |  |  |         self._install_signal_handlers() | 
			
		
	
		
		
			
				
					
					|  |  |  |         did_perform_work = False |  |  |  |         did_perform_work = False | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.register_birth() |  |  |  |         self.register_birth() | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.log.info("RQ worker {0!r} started, version {1}".format(self.key, VERSION)) |  |  |  |         self.log.info("RQ worker %r started, version %s", self.key, VERSION) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         self.set_state(WorkerStatus.STARTED) |  |  |  |         self.set_state(WorkerStatus.STARTED) | 
			
		
	
		
		
			
				
					
					|  |  |  |         qnames = self.queue_names() |  |  |  |         qnames = self.queue_names() | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.log.info('*** Listening on %s...', green(', '.join(qnames))) |  |  |  |         self.log.info('*** Listening on %s...', green(', '.join(qnames))) | 
			
		
	
	
		
		
			
				
					|  |  | @ -491,7 +491,7 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  |                     result = self.dequeue_job_and_maintain_ttl(timeout) |  |  |  |                     result = self.dequeue_job_and_maintain_ttl(timeout) | 
			
		
	
		
		
			
				
					
					|  |  |  |                     if result is None: |  |  |  |                     if result is None: | 
			
		
	
		
		
			
				
					
					|  |  |  |                         if burst: |  |  |  |                         if burst: | 
			
		
	
		
		
			
				
					
					|  |  |  |                             self.log.info("RQ worker {0!r} done, quitting".format(self.key)) |  |  |  |                             self.log.info("RQ worker %r done, quitting", self.key) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |                         break |  |  |  |                         break | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                     job, queue = result |  |  |  |                     job, queue = result | 
			
		
	
	
		
		
			
				
					|  |  | @ -526,12 +526,12 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                     job, queue = result |  |  |  |                     job, queue = result | 
			
		
	
		
		
			
				
					
					|  |  |  |                     if self.log_job_description: |  |  |  |                     if self.log_job_description: | 
			
		
	
		
		
			
				
					
					|  |  |  |                         self.log.info('{0}: {1} ({2})'.format(green(queue.name), |  |  |  |                         self.log.info('%s: %s (%s)', green(queue.name), | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |                                                      blue(job.description), |  |  |  |                                                      blue(job.description), | 
			
		
	
		
		
			
				
					
					|  |  |  |                                                               job.id)) |  |  |  |                                                      job.id) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |                     else: |  |  |  |                     else: | 
			
		
	
		
		
			
				
					
					|  |  |  |                         self.log.info('{0}:{1}'.format(green(queue.name), |  |  |  |                         self.log.info('%s:%s', green(queue.name), | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                                                        job.id)) |  |  |  |                                                        job.id) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |                 break |  |  |  |                 break | 
			
		
	
		
		
			
				
					
					|  |  |  |             except DequeueTimeout: |  |  |  |             except DequeueTimeout: | 
			
		
	
	
		
		
			
				
					|  |  | @ -652,9 +652,9 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |             # Unhandled failure: move the job to the failed queue |  |  |  |             # Unhandled failure: move the job to the failed queue | 
			
		
	
		
		
			
				
					
					|  |  |  |             self.log.warning(( |  |  |  |             self.log.warning(( | 
			
		
	
		
		
			
				
					
					|  |  |  |                 'Moving job to {0!r} queue ' |  |  |  |                 'Moving job to %r queue ' | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |                 '(work-horse terminated unexpectedly; waitpid returned {1})' |  |  |  |                 '(work-horse terminated unexpectedly; waitpid returned %s)' | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |             ).format(self.failed_queue.name, ret_val)) |  |  |  |             ), self.failed_queue.name, ret_val) | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             self.failed_queue.quarantine( |  |  |  |             self.failed_queue.quarantine( | 
			
		
	
		
		
			
				
					
					|  |  |  |                 job, |  |  |  |                 job, | 
			
		
	
		
		
			
				
					
					|  |  |  |                 exc_info=( |  |  |  |                 exc_info=( | 
			
		
	
	
		
		
			
				
					|  |  | @ -827,7 +827,7 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  |         finally: |  |  |  |         finally: | 
			
		
	
		
		
			
				
					
					|  |  |  |             pop_connection() |  |  |  |             pop_connection() | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.log.info('{0}: {1} ({2})'.format(green(job.origin), blue('Job OK'), job.id)) |  |  |  |         self.log.info('%s: %s (%s)', green(job.origin), blue('Job OK'), job.id) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         if rv is not None: |  |  |  |         if rv is not None: | 
			
		
	
		
		
			
				
					
					|  |  |  |             log_result = "{0!r}".format(as_text(text_type(rv))) |  |  |  |             log_result = "{0!r}".format(as_text(text_type(rv))) | 
			
		
	
		
		
			
				
					
					|  |  |  |             self.log.debug('Result: %s', yellow(log_result)) |  |  |  |             self.log.debug('Result: %s', yellow(log_result)) | 
			
		
	
	
		
		
			
				
					|  |  | @ -837,9 +837,9 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  |             if result_ttl == 0: |  |  |  |             if result_ttl == 0: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 self.log.info('Result discarded immediately') |  |  |  |                 self.log.info('Result discarded immediately') | 
			
		
	
		
		
			
				
					
					|  |  |  |             elif result_ttl > 0: |  |  |  |             elif result_ttl > 0: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 self.log.info('Result is kept for {0} seconds'.format(result_ttl)) |  |  |  |                 self.log.info('Result is kept for %s seconds', result_ttl) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             else: |  |  |  |             else: | 
			
		
	
		
		
			
				
					
					|  |  |  |                 self.log.warning('Result will never expire, clean up result key manually') |  |  |  |                 self.log.info('Result will never expire, clean up result key manually') | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         return True |  |  |  |         return True | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -869,7 +869,7 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     def move_to_failed_queue(self, job, *exc_info): |  |  |  |     def move_to_failed_queue(self, job, *exc_info): | 
			
		
	
		
		
			
				
					
					|  |  |  |         """Default exception handler: move the job to the failed queue.""" |  |  |  |         """Default exception handler: move the job to the failed queue.""" | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.log.warning('Moving job to {0!r} queue'.format(self.failed_queue.name)) |  |  |  |         self.log.warning('Moving job to %r queue', self.failed_queue.name) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |         from .handlers import move_to_failed_queue |  |  |  |         from .handlers import move_to_failed_queue | 
			
		
	
		
		
			
				
					
					|  |  |  |         move_to_failed_queue(job, *exc_info) |  |  |  |         move_to_failed_queue(job, *exc_info) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -904,7 +904,7 @@ class Worker(object): | 
			
		
	
		
		
			
				
					
					|  |  |  |     def clean_registries(self): |  |  |  |     def clean_registries(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |         """Runs maintenance jobs on each Queue's registries.""" |  |  |  |         """Runs maintenance jobs on each Queue's registries.""" | 
			
		
	
		
		
			
				
					
					|  |  |  |         for queue in self.queues: |  |  |  |         for queue in self.queues: | 
			
		
	
		
		
			
				
					
					|  |  |  |             self.log.info('Cleaning registries for queue: {0}'.format(queue.name)) |  |  |  |             self.log.info('Cleaning registries for queue: %s', queue.name) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             clean_registries(queue) |  |  |  |             clean_registries(queue) | 
			
		
	
		
		
			
				
					
					|  |  |  |         self.last_cleaned_at = utcnow() |  |  |  |         self.last_cleaned_at = utcnow() | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -952,7 +952,7 @@ class HerokuWorker(Worker): | 
			
		
	
		
		
			
				
					
					|  |  |  |     def handle_warm_shutdown_request(self): |  |  |  |     def handle_warm_shutdown_request(self): | 
			
		
	
		
		
			
				
					
					|  |  |  |         """If horse is alive send it SIGRTMIN""" |  |  |  |         """If horse is alive send it SIGRTMIN""" | 
			
		
	
		
		
			
				
					
					|  |  |  |         if self.horse_pid != 0: |  |  |  |         if self.horse_pid != 0: | 
			
		
	
		
		
			
				
					
					|  |  |  |             self.log.warning('Warm shut down requested, sending horse SIGRTMIN signal') |  |  |  |             self.log.info('Warm shut down requested, sending horse SIGRTMIN signal') | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |             self.kill_horse(sig=signal.SIGRTMIN) |  |  |  |             self.kill_horse(sig=signal.SIGRTMIN) | 
			
		
	
		
		
			
				
					
					|  |  |  |         else: |  |  |  |         else: | 
			
		
	
		
		
			
				
					
					|  |  |  |             self.log.warning('Warm shut down requested, no horse found') |  |  |  |             self.log.warning('Warm shut down requested, no horse found') | 
			
		
	
	
		
		
			
				
					|  |  | 
 |