.. _cluster-FAQ: === FAQ === These are some Frequently Asked Questions for Ray clusters. If you still have questions after reading this FAQ, reach out on the `Ray Discourse forum `__. Do Ray clusters support multi-tenancy? ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Yes, you can run multiple :ref:`jobs ` from different users simultaneously in a Ray cluster but it's not recommended in production. Some Ray features are still missing for multi-tenancy in production: * Ray doesn't provide strong resource isolation: Ray :ref:`resources ` are logical and they don't limit the physical resources a task or actor can use while running. This means simultaneous jobs can interfere with each other and makes them less reliable to run in production. * Ray doesn't support priorities: All jobs, tasks and actors have the same priority so there is no way to prioritize important jobs under load. * Ray doesn't support access control: Jobs have full access to a Ray cluster and all of the resources within it. On the other hand, you can run the same job multiple times using the same cluster to save the cluster startup time. .. note:: A Ray :ref:`namespace ` is just a logical grouping of jobs and named actors. Unlike a Kubernetes namespace, it doesn't provide any other multi-tenancy functions like resource quotas. I have multiple Ray users. What's the right way to deploy Ray for them? ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ Start a Ray cluster for each user to isolate their workloads. What's the difference between ``--node-ip-address`` and ``--address``? ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ When starting a head node on a machine with more than one network address, you may need to specify the externally available address so worker nodes can connect. Use this command: .. code:: bash ray start --head --node-ip-address xx.xx.xx.xx --port nnnn`` Then when starting the worker node, use this command to connect to the head node: .. code:: bash ray start --address xx.xx.xx.xx:nnnn What does a worker node failure to connect look like? ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ If the worker node can't connect to the head node, you should see this error: Unable to connect to GCS at xx.xx.xx.xx:nnnn. Check that (1) Ray GCS with matching version started successfully at the specified address, and (2) there is no firewall setting preventing access. The most likely cause is that the worker node can't access the IP address given. You can use ``ip route get xx.xx.xx.xx`` on the worker node to start debugging routing issues. You may also see failures in the log like: This node has an IP address of xx.xx.xx.xx, while we can not found the matched Raylet address. This maybe come from when you connect the Ray cluster with a different IP address or connect a container. The cause of this error may be the head node overloading with too many simultaneous connections. The solution for this problem is to start the worker nodes more slowly. Problems getting a SLURM cluster to work ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ A class of issues exist with starting Ray on SLURM clusters. While the exact causes aren't understood, (as of June 2023), some Ray improvements mitigate some of the resource contention. Some of the issues reported are as follows: * Using a machine with a large number of CPUs, and starting one worker per CPU together with OpenBLAS (as used in NumPy) may allocate too many threads. This issue is a `known OpenBLAS limitation`_. You can mitigate it by limiting OpenBLAS to one thread per process as explained in the link. * Resource allocation isn't as expected: usually the configuration has too many CPUs allocated per node. The best practice is to verify the SLURM configuration without starting Ray to verify that the allocations are as expected. For more detailed information see :ref:`ray-slurm-deploy`. .. _`known OpenBLAS limitation`: https://github.com/xianyi/OpenBLAS/wiki/faq#how-can-i-use-openblas-in-multi-threaded-applications Where does my Ray Job entrypoint script run? On the head node or worker nodes? ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ By default, jobs submitted using the :ref:`Ray Job API ` run their `entrypoint` script on the head node. You can change this by specifying any of the options `--entrypoint-num-cpus`, `--entrypoint-num-gpus`, `--entrypoint-resources` or `--entrypoint-memory` to `ray job submit`, or the corresponding arguments if using the Python SDK. If these are specified, the job entrypoint will be scheduled on a node that has the requested resources available.