mirror of
https://github.com/wassname/ray.git
synced 2026-06-27 19:00:36 +08:00
Add Redis port option to startup script (#232)
* specify redis address when starting head * cleanup * update starting cluster documentation * Whitespace. * Address Philipp's comments. * Change redis_host -> redis_ip_address.
This commit is contained in:
committed by
Robert Nishihara
parent
db7297865f
commit
6ad2b5d87a
+21
-9
@@ -9,13 +9,14 @@ import ray.services as services
|
||||
|
||||
parser = argparse.ArgumentParser(description="Parse addresses for the worker to connect to.")
|
||||
parser.add_argument("--node-ip-address", required=False, type=str, help="the IP address of the worker's node")
|
||||
parser.add_argument("--redis-address", required=False, type=str, help="the address to use for Redis")
|
||||
parser.add_argument("--redis-address", required=False, type=str, help="the address to use for connecting to Redis")
|
||||
parser.add_argument("--redis-port", required=False, type=str, help="the port to use for starting Redis")
|
||||
parser.add_argument("--num-workers", default=10, required=False, type=int, help="the number of workers to start on this node")
|
||||
parser.add_argument("--head", action="store_true", help="provide this argument for the head node")
|
||||
|
||||
def check_no_existing_redis_clients(node_ip_address, redis_address):
|
||||
redis_host, redis_port = redis_address.split(":")
|
||||
redis_client = redis.StrictRedis(host=redis_host, port=int(redis_port))
|
||||
redis_ip_address, redis_port = redis_address.split(":")
|
||||
redis_client = redis.StrictRedis(host=redis_ip_address, port=int(redis_port))
|
||||
# The client table prefix must be kept in sync with the file
|
||||
# "src/common/redis_module/ray_redis_module.c" where it is defined.
|
||||
REDIS_CLIENT_TABLE_PREFIX = "CL:"
|
||||
@@ -41,16 +42,25 @@ if __name__ == "__main__":
|
||||
# Start Ray on the head node.
|
||||
if args.redis_address is not None:
|
||||
raise Exception("If --head is passed in, a Redis server will be started, so a Redis address should not be provided.")
|
||||
|
||||
# Get the node IP address if one is not provided.
|
||||
if args.node_ip_address is None:
|
||||
node_ip_address = services.get_node_ip_address()
|
||||
else:
|
||||
node_ip_address = args.node_ip_address
|
||||
print("Using IP address {} for this node.".format(node_ip_address))
|
||||
address_info = services.start_ray_local(node_ip_address=node_ip_address,
|
||||
num_workers=args.num_workers,
|
||||
cleanup=False,
|
||||
redirect_output=True)
|
||||
|
||||
if args.redis_port is not None:
|
||||
address_info = {"redis_address": "{}:{}".format(node_ip_address,
|
||||
args.redis_port)}
|
||||
else:
|
||||
address_info = None
|
||||
|
||||
address_info = services.start_ray_head(address_info=address_info,
|
||||
node_ip_address=node_ip_address,
|
||||
num_workers=args.num_workers,
|
||||
cleanup=False,
|
||||
redirect_output=True)
|
||||
print(address_info)
|
||||
print("\nStarted Ray with {} workers on this node. A different number of "
|
||||
"workers can be set with the --num-workers flag (but you have to "
|
||||
@@ -69,12 +79,14 @@ if __name__ == "__main__":
|
||||
address_info["redis_address"]))
|
||||
else:
|
||||
# Start Ray on a non-head node.
|
||||
if args.redis_port is not None:
|
||||
raise Exception("If --head is not passed in, --redis-port is not allowed")
|
||||
if args.redis_address is None:
|
||||
raise Exception("If --head is not passed in, --redis-address must be provided.")
|
||||
redis_host, redis_port = args.redis_address.split(":")
|
||||
redis_ip_address, redis_port = args.redis_address.split(":")
|
||||
# Wait for the Redis server to be started. And throw an exception if we
|
||||
# can't connect to it.
|
||||
services.wait_for_redis_to_start(redis_host, int(redis_port))
|
||||
services.wait_for_redis_to_start(redis_ip_address, int(redis_port))
|
||||
# Get the node IP address if one is not provided.
|
||||
if args.node_ip_address is None:
|
||||
node_ip_address = services.get_node_ip_address(args.redis_address)
|
||||
|
||||
Reference in New Issue
Block a user