diff --git a/rq/scripts/__init__.py b/rq/scripts/__init__.py index 0e2ed9774..fc31d092f 100644 --- a/rq/scripts/__init__.py +++ b/rq/scripts/__init__.py @@ -7,7 +7,8 @@ def add_standard_arguments(parser): parser.add_argument('--config', '-c', default=None, help='Module containing RQ settings.') parser.add_argument('--url', '-u', default=None, - help='URL describing Redis connection details') + help='URL describing Redis connection details. ' + 'Overrides other connection arguments if supplied.') parser.add_argument('--host', '-H', default=None, help='The Redis hostname (default: localhost)') parser.add_argument('--port', '-p', default=None, @@ -47,13 +48,10 @@ def setup_default_arguments(args, settings): if args.password is None: args.password = settings.get('REDIS_PASSWORD', None) - if not args.queues: - args.queues = settings.get('QUEUES', ['default']) - def setup_redis(args): if args.url is not None: - redis_conn = redis.StrictRedis.from_url(args.url, db=args.db) + redis_conn = redis.StrictRedis.from_url(args.url) else: redis_conn = redis.StrictRedis(host=args.host, port=args.port, db=args.db, password=args.password, unix_socket_path=args.socket) diff --git a/rq/scripts/rqinfo.py b/rq/scripts/rqinfo.py index 7e036474b..df16eb286 100755 --- a/rq/scripts/rqinfo.py +++ b/rq/scripts/rqinfo.py @@ -21,6 +21,7 @@ def pad(s, pad_to_length): """Pads the given string to the given length.""" return ('%-' + '%ds' % pad_to_length) % (s,) + def get_scale(x): """Finds the lowest scale where x <= scale.""" scales = [20, 50, 100, 200, 400, 600, 800, 1000] @@ -29,6 +30,7 @@ def get_scale(x): return scale return x + def state_symbol(state): symbols = { 'busy': red('busy'), @@ -186,4 +188,3 @@ def main(): except KeyboardInterrupt: print sys.exit(0) - diff --git a/rq/scripts/rqworker.py b/rq/scripts/rqworker.py index 19073eab5..29505caee 100755 --- a/rq/scripts/rqworker.py +++ b/rq/scripts/rqworker.py @@ -32,6 +32,19 @@ def parse_args(): return parser.parse_args() +def setup_loghandlers_from_args(args): + if args.verbose and args.quiet: + raise RuntimeError("Flags --verbose and --quiet are mutually exclusive.") + + if args.verbose: + level = 'DEBUG' + elif args.quiet: + level = 'WARNING' + else: + level = 'INFO' + setup_loghandlers(level) + + def main(): args = parse_args() @@ -44,21 +57,15 @@ def main(): setup_default_arguments(args, settings) - # Other default arguments + # Worker specific default arguments + if not args.queues: + args.queues = settings.get('QUEUES', ['default']) + if args.sentry_dsn is None: args.sentry_dsn = settings.get('SENTRY_DSN', os.environ.get('SENTRY_DSN', None)) - if args.verbose and args.quiet: - raise RuntimeError("Flags --verbose and --quiet are mutually exclusive.") - - if args.verbose: - level = 'DEBUG' - elif args.quiet: - level = 'WARNING' - else: - level = 'INFO' - setup_loghandlers(level) + setup_loghandlers_from_args(args) setup_redis(args) cleanup_ghosts()