|  |  | @ -25,11 +25,13 @@ from rq.defaults import (DEFAULT_CONNECTION_CLASS, DEFAULT_JOB_CLASS, | 
			
		
	
		
		
			
				
					
					|  |  |  | from rq.exceptions import InvalidJobOperationError |  |  |  | from rq.exceptions import InvalidJobOperationError | 
			
		
	
		
		
			
				
					
					|  |  |  | from rq.registry import FailedJobRegistry, clean_registries |  |  |  | from rq.registry import FailedJobRegistry, clean_registries | 
			
		
	
		
		
			
				
					
					|  |  |  | from rq.utils import import_attribute |  |  |  | from rq.utils import import_attribute | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | from rq.serializers import DefaultSerializer | 
			
		
	
		
		
			
				
					
					|  |  |  | from rq.suspension import (suspend as connection_suspend, |  |  |  | from rq.suspension import (suspend as connection_suspend, | 
			
		
	
		
		
			
				
					
					|  |  |  |                            resume as connection_resume, is_suspended) |  |  |  |                            resume as connection_resume, is_suspended) | 
			
		
	
		
		
			
				
					
					|  |  |  | from rq.worker_registration import clean_worker_registry |  |  |  | from rq.worker_registration import clean_worker_registry | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | # Disable the warning that Click displays (as of Click version 5.0) when users |  |  |  | # Disable the warning that Click displays (as of Click version 5.0) when users | 
			
		
	
		
		
			
				
					
					|  |  |  | # use unicode_literals in Python 2. |  |  |  | # use unicode_literals in Python 2. | 
			
		
	
		
		
			
				
					
					|  |  |  | # See http://click.pocoo.org/dev/python3/#unicode-literals for more details. |  |  |  | # See http://click.pocoo.org/dev/python3/#unicode-literals for more details. | 
			
		
	
	
		
		
			
				
					|  |  | @ -62,7 +64,10 @@ shared_options = [ | 
			
		
	
		
		
			
				
					
					|  |  |  |     click.option('--path', '-P', |  |  |  |     click.option('--path', '-P', | 
			
		
	
		
		
			
				
					
					|  |  |  |                  default='.', |  |  |  |                  default='.', | 
			
		
	
		
		
			
				
					
					|  |  |  |                  help='Specify the import path.', |  |  |  |                  help='Specify the import path.', | 
			
		
	
		
		
			
				
					
					|  |  |  |                  multiple=True) |  |  |  |                  multiple=True), | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     click.option('--serializer', '-S', | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                  default=DefaultSerializer, | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |                  help='Path to serializer, defaults to rq.serializers.DefaultSerializer') | 
			
		
	
		
		
			
				
					
					|  |  |  | ] |  |  |  | ] | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -203,13 +208,14 @@ def info(cli_config, interval, raw, only_queues, only_workers, by_queue, queues, | 
			
		
	
		
		
			
				
					
					|  |  |  | @click.option('--disable-default-exception-handler', '-d', is_flag=True, help='Disable RQ\'s default exception handler') |  |  |  | @click.option('--disable-default-exception-handler', '-d', is_flag=True, help='Disable RQ\'s default exception handler') | 
			
		
	
		
		
			
				
					
					|  |  |  | @click.option('--max-jobs', type=int, default=None, help='Maximum number of jobs to execute') |  |  |  | @click.option('--max-jobs', type=int, default=None, help='Maximum number of jobs to execute') | 
			
		
	
		
		
			
				
					
					|  |  |  | @click.option('--with-scheduler', '-s', is_flag=True, help='Run worker with scheduler') |  |  |  | @click.option('--with-scheduler', '-s', is_flag=True, help='Run worker with scheduler') | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | @click.option('--serializer', '-S', default=None, help='Run worker with custom serializer') | 
			
		
	
		
		
			
				
					
					|  |  |  | @click.argument('queues', nargs=-1) |  |  |  | @click.argument('queues', nargs=-1) | 
			
		
	
		
		
			
				
					
					|  |  |  | @pass_cli_config |  |  |  | @pass_cli_config | 
			
		
	
		
		
			
				
					
					|  |  |  | def worker(cli_config, burst, logging_level, name, results_ttl, |  |  |  | def worker(cli_config, burst, logging_level, name, results_ttl, | 
			
		
	
		
		
			
				
					
					|  |  |  |            worker_ttl, job_monitoring_interval, disable_job_desc_logging, |  |  |  |            worker_ttl, job_monitoring_interval, disable_job_desc_logging, | 
			
		
	
		
		
			
				
					
					|  |  |  |            verbose, quiet, sentry_ca_certs, sentry_debug, sentry_dsn, |  |  |  |            verbose, quiet, sentry_ca_certs, sentry_debug, sentry_dsn, | 
			
		
	
		
		
			
				
					
					|  |  |  |            exception_handler, pid, disable_default_exception_handler, max_jobs, |  |  |  |            exception_handler, pid, disable_default_exception_handler, max_jobs, | 
			
		
	
		
		
			
				
					
					|  |  |  |            with_scheduler, queues, log_format, date_format, **options): |  |  |  |            with_scheduler, queues, log_format, date_format, serializer, **options): | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     """Starts an RQ worker.""" |  |  |  |     """Starts an RQ worker.""" | 
			
		
	
		
		
			
				
					
					|  |  |  |     settings = read_config_file(cli_config.config) if cli_config.config else {} |  |  |  |     settings = read_config_file(cli_config.config) if cli_config.config else {} | 
			
		
	
		
		
			
				
					
					|  |  |  |     # Worker specific default arguments |  |  |  |     # Worker specific default arguments | 
			
		
	
	
		
		
			
				
					|  |  | @ -226,7 +232,6 @@ def worker(cli_config, burst, logging_level, name, results_ttl, | 
			
		
	
		
		
			
				
					
					|  |  |  |     setup_loghandlers_from_args(verbose, quiet, date_format, log_format) |  |  |  |     setup_loghandlers_from_args(verbose, quiet, date_format, log_format) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     try: |  |  |  |     try: | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |         cleanup_ghosts(cli_config.connection) |  |  |  |         cleanup_ghosts(cli_config.connection) | 
			
		
	
		
		
			
				
					
					|  |  |  |         exception_handlers = [] |  |  |  |         exception_handlers = [] | 
			
		
	
		
		
			
				
					
					|  |  |  |         for h in exception_handler: |  |  |  |         for h in exception_handler: | 
			
		
	
	
		
		
			
				
					|  |  | @ -247,7 +252,8 @@ def worker(cli_config, burst, logging_level, name, results_ttl, | 
			
		
	
		
		
			
				
					
					|  |  |  |             job_class=cli_config.job_class, queue_class=cli_config.queue_class, |  |  |  |             job_class=cli_config.job_class, queue_class=cli_config.queue_class, | 
			
		
	
		
		
			
				
					
					|  |  |  |             exception_handlers=exception_handlers or None, |  |  |  |             exception_handlers=exception_handlers or None, | 
			
		
	
		
		
			
				
					
					|  |  |  |             disable_default_exception_handler=disable_default_exception_handler, |  |  |  |             disable_default_exception_handler=disable_default_exception_handler, | 
			
		
	
		
		
			
				
					
					|  |  |  |             log_job_description=not disable_job_desc_logging |  |  |  |             log_job_description=not disable_job_desc_logging, | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |             serializer=serializer | 
			
		
	
		
		
			
				
					
					|  |  |  |         ) |  |  |  |         ) | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |         # Should we configure Sentry? |  |  |  |         # Should we configure Sentry? | 
			
		
	
	
		
		
			
				
					|  |  | 
 |