Made rqworker and rqinfo respect db parameters from --url

When starting the rqworker and rqinfo scripts with an --url parameter containing a non default database, e.g. redis://localhost:6379/2, both scripts connected db 0 instead of the desired database. Fixed this behavior by ignoring the --host, --port and --db arguments if --url is there.

Also fixed another issue with the rqinfo script, in which it defaulted to only the 'default' queue instead of finding all available queues using Queue.all().
main
Jóhann Þorvaldur Bergþórsson 12 years ago
parent 5a5e14cc70
commit 7660fbdc18

@ -7,7 +7,8 @@ def add_standard_arguments(parser):
parser.add_argument('--config', '-c', default=None, parser.add_argument('--config', '-c', default=None,
help='Module containing RQ settings.') help='Module containing RQ settings.')
parser.add_argument('--url', '-u', default=None, 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, parser.add_argument('--host', '-H', default=None,
help='The Redis hostname (default: localhost)') help='The Redis hostname (default: localhost)')
parser.add_argument('--port', '-p', default=None, parser.add_argument('--port', '-p', default=None,
@ -42,13 +43,10 @@ def setup_default_arguments(args, settings):
if args.password is None: if args.password is None:
args.password = settings.get('REDIS_PASSWORD', None) args.password = settings.get('REDIS_PASSWORD', None)
if not args.queues:
args.queues = settings.get('QUEUES', ['default'])
def setup_redis(args): def setup_redis(args):
if args.url is not None: 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: else:
redis_conn = redis.StrictRedis(host=args.host, port=args.port, db=args.db, redis_conn = redis.StrictRedis(host=args.host, port=args.port, db=args.db,
password=args.password) password=args.password)

@ -21,6 +21,7 @@ def pad(s, pad_to_length):
"""Pads the given string to the given length.""" """Pads the given string to the given length."""
return ('%-' + '%ds' % pad_to_length) % (s,) return ('%-' + '%ds' % pad_to_length) % (s,)
def get_scale(x): def get_scale(x):
"""Finds the lowest scale where x <= scale.""" """Finds the lowest scale where x <= scale."""
scales = [20, 50, 100, 200, 400, 600, 800, 1000] scales = [20, 50, 100, 200, 400, 600, 800, 1000]
@ -29,6 +30,7 @@ def get_scale(x):
return scale return scale
return x return x
def state_symbol(state): def state_symbol(state):
symbols = { symbols = {
'busy': red('busy'), 'busy': red('busy'),
@ -186,4 +188,3 @@ def main():
except KeyboardInterrupt: except KeyboardInterrupt:
print print
sys.exit(0) sys.exit(0)

@ -31,6 +31,19 @@ def parse_args():
return parser.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(): def main():
args = parse_args() args = parse_args()
@ -43,20 +56,14 @@ def main():
setup_default_arguments(args, settings) 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: if args.sentry_dsn is None:
args.sentry_dsn = settings.get('SENTRY_DSN', None) args.sentry_dsn = settings.get('SENTRY_DSN', None)
if args.verbose and args.quiet: setup_loghandlers_from_args(args)
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_redis(args) setup_redis(args)
cleanup_ghosts() cleanup_ghosts()

Loading…
Cancel
Save