Skip to content

Commit

Permalink
Merge branch 'main' into azureml-hpo
Browse files Browse the repository at this point in the history
  • Loading branch information
melodywang060 authored Oct 11, 2024
2 parents 031a8fd + 7ed98fb commit 7d10373
Show file tree
Hide file tree
Showing 9 changed files with 32 additions and 41 deletions.
3 changes: 2 additions & 1 deletion conda/environments/deployment_docs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ dependencies:
- pydata-sphinx-theme>=0.15.4
- python=3.12
- pre-commit>=3.8.0
- sphinx>=8.0.2
# Upper bound pin on sphinx can be removed once https://github.com/mgaitan/sphinxcontrib-mermaid/issues/160 is resolved
- sphinx>=8.0.2,<8.1
- sphinx-autobuild>=2024.9.19
- sphinx-copybutton>=0.5.2
- sphinx-design>=0.6.1
Expand Down
32 changes: 11 additions & 21 deletions source/cloud/aws/eks.md
Original file line number Diff line number Diff line change
Expand Up @@ -24,16 +24,15 @@ Now we can launch a GPU enabled EKS cluster. First launch an EKS cluster with `e

```console
$ eksctl create cluster rapids \
--version 1.24 \
--version 1.29 \
--nodes 3 \
--node-type=p3.8xlarge \
--timeout=40m \
--ssh-access \
--ssh-public-key <public key ID> \ # Be sure to set your public key ID here
--region us-east-1 \
--zones=us-east-1c,us-east-1b,us-east-1d \
--auto-kubeconfig \
--install-nvidia-plugin=false
--auto-kubeconfig
```

With this command, you’ve launched an EKS cluster called `rapids`. You’ve specified that it should use nodes of type `p3.8xlarge`. We also specified that we don't want to install the NVIDIA drivers as we will do that with the NVIDIA operator.
Expand All @@ -46,30 +45,21 @@ $ aws eks --region us-east-1 update-kubeconfig --name rapids

## Install drivers

Next, [install the NVIDIA drivers](https://docs.nvidia.com/datacenter/cloud-native/gpu-operator/getting-started.html) onto each node.
As we selected a GPU node type EKS will automatically install drivers for us. We can verify this by listing the NVIDIA driver plugin Pods.

```console
$ helm install --repo https://helm.ngc.nvidia.com/nvidia --wait --generate-name -n gpu-operator --create-namespace gpu-operator
NAME: gpu-operator-1670843572
NAMESPACE: gpu-operator
STATUS: deployed
REVISION: 1
TEST SUITE: None
$ kubectl get po -n kube-system -l name=nvidia-device-plugin-ds
NAME READY STATUS RESTARTS AGE
nvidia-device-plugin-daemonset-kv7t5 1/1 Running 0 52m
nvidia-device-plugin-daemonset-rhmvx 1/1 Running 0 52m
nvidia-device-plugin-daemonset-thjhc 1/1 Running 0 52m
```

Verify that the NVIDIA drivers are successfully installed.

```console
$ kubectl get po -A --watch | grep nvidia
kube-system nvidia-driver-installer-6zwcn 1/1 Running 0 8m47s
kube-system nvidia-driver-installer-8zmmn 1/1 Running 0 8m47s
kube-system nvidia-driver-installer-mjkb8 1/1 Running 0 8m47s
kube-system nvidia-gpu-device-plugin-5ffkm 1/1 Running 0 13m
kube-system nvidia-gpu-device-plugin-d599s 1/1 Running 0 13m
kube-system nvidia-gpu-device-plugin-jrgjh 1/1 Running 0 13m
```{note}
By default this plugin will install the latest version on the NVIDIA drivers on every Node. If you need more control over your driver installation we recommend that when creating your cluster you set `eksctl create cluster --install-nvidia-plugin=false ...` and then install drivers yourself using the [NVIDIA GPU Operator](https://docs.nvidia.com/datacenter/cloud-native/gpu-operator/getting-started.html).
```

After your drivers are installed, you are ready to test your cluster.
After you have confirmed your drivers are installed, you are ready to test your cluster.

```{include} ../../_includes/check-gpu-pod-works.md
Expand Down
2 changes: 1 addition & 1 deletion source/cloud/azure/azure-vm.md
Original file line number Diff line number Diff line change
Expand Up @@ -128,7 +128,7 @@ Next, we can SSH into our VM to install RAPIDS. SSH instructions can be found by

### Useful Links

- [Using NGC with Azure](https://docs.nvidia.com/ngc/ngc-azure-setup-guide/index.html)
- [Using NGC with Azure](https://docs.nvidia.com/ngc/ngc-deploy-public-cloud/ngc-azure/index.html)

```{relatedexamples}
Expand Down
16 changes: 8 additions & 8 deletions source/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,25 +21,25 @@
author = "NVIDIA"

# Single modifiable version for all of the docs - easier for future updates
stable_version = "24.08"
nightly_version = "24.10"
stable_version = "24.10"
nightly_version = "24.12"

versions = {
"stable": {
"rapids_version": stable_version,
"rapids_api_docs_version": "stable",
"rapids_container": f"nvcr.io/nvidia/rapidsai/base:{stable_version}-cuda12.5-py3.11",
"rapids_notebooks_container": f"nvcr.io/nvidia/rapidsai/notebooks:{stable_version}-cuda12.5-py3.11",
"rapids_container": f"nvcr.io/nvidia/rapidsai/base:{stable_version}-cuda12.5-py3.12",
"rapids_notebooks_container": f"nvcr.io/nvidia/rapidsai/notebooks:{stable_version}-cuda12.5-py3.12",
"rapids_conda_channels": "-c rapidsai -c conda-forge -c nvidia",
"rapids_conda_packages": f"rapids={stable_version} python=3.11 cuda-version=12.5",
"rapids_conda_packages": f"rapids={stable_version} python=3.12 cuda-version=12.5",
},
"nightly": {
"rapids_version": f"{nightly_version}-nightly",
"rapids_api_docs_version": "nightly",
"rapids_container": f"rapidsai/base:{nightly_version + 'a'}-cuda12.5-py3.11",
"rapids_notebooks_container": f"rapidsai/notebooks:{nightly_version + 'a'}-cuda12.5-py3.11",
"rapids_container": f"rapidsai/base:{nightly_version + 'a'}-cuda12.5-py3.12",
"rapids_notebooks_container": f"rapidsai/notebooks:{nightly_version + 'a'}-cuda12.5-py3.12",
"rapids_conda_channels": "-c rapidsai-nightly -c conda-forge -c nvidia",
"rapids_conda_packages": f"rapids={nightly_version} python=3.11 cuda-version=12.5",
"rapids_conda_packages": f"rapids={nightly_version} python=3.12 cuda-version=12.5",
},
}
rapids_version = (
Expand Down
4 changes: 2 additions & 2 deletions source/examples/rapids-azureml-hpo/notebook.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@
"cell_type": "markdown",
"metadata": {},
"source": [
"Initialize`MLClient`[class](https://learn.microsoft.com/en-us/python/api/azure-ai-ml/azure.ai.ml.mlclient?view=azure-python) to handle the workspace you created in the prerequisites step. \n",
"Initialize `MLClient` [class](https://learn.microsoft.com/en-us/python/api/azure-ai-ml/azure.ai.ml.mlclient?view=azure-python) to handle the workspace you created in the prerequisites step. \n",
"\n",
"You can manually provide the workspace details or call `MLClient.from_config(credential, path)`\n",
"to create a workspace object from the details stored in `config.json`"
Expand Down Expand Up @@ -307,7 +307,7 @@
"cell_type": "markdown",
"metadata": {},
"source": [
"We'll be using a custom RAPIDS docker image to [setup the environment]((https://learn.microsoft.com/en-us/azure/machine-learning/how-to-manage-environments-v2?tabs=python#create-an-environment-from-a-docker-image). This is available in `rapidsai/rapidsai` repo on [DockerHub](https://hub.docker.com/r/rapidsai/rapidsai/).\n",
"We'll be using a custom RAPIDS docker image to [setup the environment](https://learn.microsoft.com/en-us/azure/machine-learning/how-to-manage-environments-v2?tabs=python#create-an-environment-from-a-docker-image). This is available in `rapidsai/rapidsai` repo on [DockerHub](https://hub.docker.com/r/rapidsai/rapidsai/).\n",
"\n",
"Make sure you have the correct path to the docker build context as `os.getcwd()`,"
]
Expand Down
4 changes: 2 additions & 2 deletions source/examples/rapids-optuna-hpo/notebook.ipynb
Original file line number Diff line number Diff line change
Expand Up @@ -277,7 +277,7 @@
" \n",
"Optuna uses [studies](https://optuna.readthedocs.io/en/stable/reference/study.html) and [trials](https://optuna.readthedocs.io/en/stable/reference/trial.html) to keep track of the HPO experiments. Put simply, a trial is a single call of the objective function while a set of trials make up a study. We will pick the best observed trial from a study to get the best parameters that were used in that run.\n",
"\n",
"Here, `DaskStorage` class is used to set up a storage shared by all workers in the cluster. Learn more about what storages can be used [here](https://optuna.readthedocs.io/en/stable/tutorial/distributed.html)\n",
"Here, `DaskStorage` class is used to set up a storage shared by all workers in the cluster. Learn more about what storages can be used [here](https://optuna.readthedocs.io/en/stable/reference/storages.html)\n",
"\n",
"`optuna.create_study` is used to set up the study. As you can see, it specifies the study name, sampler to be used, the direction of the study, and the storage.\n",
"With just a few lines of code, we have set up a distributed HPO experiment."
Expand Down Expand Up @@ -347,7 +347,7 @@
"cell_type": "markdown",
"metadata": {},
"source": [
"## Conluding Remarks\n",
"## Concluding Remarks\n",
" \n",
"This notebook shows how RAPIDS and Optuna can be used along with dask to run multi-GPU HPO jobs, and can be used as a starting point for anyone wanting to get started with the framework. We have seen how by just adding a few lines of code we were able to integrate the libraries for a muli-GPU HPO runs. This can also be scaled to multiple nodes.\n",
" \n",
Expand Down
4 changes: 2 additions & 2 deletions source/platforms/coiled.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ To get started you need to install Coiled and login.

```console
$ conda install -c conda-forge coiled
$ coiled setup
$ coiled login
```

For more information see the [Coiled Getting Started documentation](https://docs.coiled.io/user_guide/getting_started.html).
Expand Down Expand Up @@ -82,7 +82,7 @@ We can also connect a Dask client to see that information for the workers too.
```python
from dask.distributed import Client

client = Client
client = Client(cluster)
client
```

Expand Down
2 changes: 1 addition & 1 deletion source/platforms/kubeflow.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ To use Dask, we need to create a scheduler and some workers that will perform ou

### Installing the Dask Kubernetes operator

To install the operator we need to create any custom resources and the operator itself, please [refer to the documentation](https://kubernetes.dask.org/en/latest/operator_installation.html) to find up-to-date installation instructions. From the terminal run the following command.
To install the operator we need to create any custom resources and the operator itself, please [refer to the documentation](https://kubernetes.dask.org/en/latest/installing.html) to find up-to-date installation instructions. From the terminal run the following command.

```console
$ helm install --repo https://helm.dask.org --create-namespace -n dask-operator --generate-name dask-kubernetes-operator
Expand Down
6 changes: 3 additions & 3 deletions source/tools/kubernetes/dask-operator.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# Dask Operator

Many libraries in RAPIDS can leverage Dask to scale out computation onto multiple GPUs and multiple nodes.
[Dask has an operator for Kubernetes](https://kubernetes.dask.org/en/latest/operator.html) which allows you to launch Dask clusters as native Kubernetes resources.
[Dask has an operator for Kubernetes](https://kubernetes.dask.org/en/latest/) which allows you to launch Dask clusters as native Kubernetes resources.

With the operator and associated Custom Resource Definitions (CRDs)
you can create `DaskCluster`, `DaskWorkerGroup` and `DaskJob` resources that describe your Dask components and the operator will
Expand Down Expand Up @@ -45,7 +45,7 @@ graph TD

Your Kubernetes cluster must have GPU nodes and have [up to date NVIDIA drivers installed](https://docs.nvidia.com/datacenter/cloud-native/gpu-operator/getting-started.html).

To install the Dask operator follow the [instructions in the Dask documentation](https://kubernetes.dask.org/en/latest/operator_installation.html).
To install the Dask operator follow the [instructions in the Dask documentation](https://kubernetes.dask.org/en/latest/installing.html).

## Configuring a RAPIDS `DaskCluster`

Expand Down Expand Up @@ -226,7 +226,7 @@ spec:
```

For the scheduler pod we are also setting the `rapidsai/base` container image, mainly to ensure our Dask versions match between
the scheduler and workers. We also disable Jupyter and ensure that the `dask-scheduler` command is configured.
the scheduler and workers. We ensure that the `dask-scheduler` command is configured.

Then we configure both the Dask communication port on `8786` and the Dask dashboard on `8787` and add some probes so that Kubernetes can monitor
the health of the scheduler.
Expand Down

0 comments on commit 7d10373

Please sign in to comment.