Run your First Distributed Training¶
This article provides a step-by-step walkthrough for running a PyTorch distributed training workload.
Distributed training is the ability to split the training of a model among multiple processors. Each processor is called a worker. Worker nodes work in parallel to speed up model training. There is also a master which coordinates the workers.
Prerequisites¶
Before you start, make sure:
- You have created a project or have one created for you.
- The project has an assigned quota of at least 1 GPU.
Step 1: Logging in¶
Browse to the provided Run:ai user interface and log in with your credentials.
Log in using the following command. You will be prompted to enter your username and password:
Run the below --help command to obtain the login options and log in according to your setup:
To use the API, you will need to obtain a token. Please follow the API authentication article.
Step 2: Submitting a distributed training workload¶
- Go to the Workload manager → Workloads
- Click +NEW WORKLOAD and select Training
- Select under which cluster to create the workload
- Select the project in which your workload will run
- Under Workload architecture, select Distributed and choose PyTorch. Set the distributed training configuration to Worker & master
- Select a preconfigured template or select the Start from scratch to launch a new workload quickly
- Enter a name for the distributed training workload (if the name already exists in the project, you will be requested to submit a different name)
- Click CONTINUE
-
Click +NEW ENVIRONMENT
a. Enter pytorch-dt as the name
b. Enter kubeflow/pytorch-dist-mnist:latest as the Image URL
c. Click CREATE ENVIRONMENT
-
When the previous screen comes up, enter 2 workers and select ‘small-fraction’ as the compute resource for your workload
- If the ‘small-fraction’ is not displayed in the gallery, follow the step-by-step guide:
Create a small-fraction compute resource
- Click +NEW COMPUTE RESOURCE
- Select under which cluster to create the compute resource
- Select a scope
- Enter a name for the compute resource. The name must be unique.
- Set GPU devices per pod - 1
-
Set GPU memory per device
- Select % (of device) - Fraction of a GPU device’s memory
-
Optional: set the CPU compute per pod - 0.1 cores (default)
- Optional: set the CPU memory per pod - 100 MB (default)
- Click CREATE COMPUTE RESOURCE
- The newly created small-fraction compute resource will be selected automatically
-
Click CONTINUE
-
Click CREATE TRAINING
After the distributed training workload is created, it is added to the workloads table.
Copy the following command to your terminal. Make sure to update the below with the name of your project and workload:
runai config project "project-name"
runai submit-dist pytorch "workload-name" --workers=2 -g 0.1 \
-i kubeflow/pytorch-dist-mnist:latest
This would start a distributed training workload based on kubeflow/pytorch-dist-mnist:latest with one master and two workers.
Copy the following command to your terminal. Make sure to update the below with the name of your project and workload:
runai project set "project-name"
runai distributed submit "workload-name" --framework PyTorch \
-i kubeflow/pytorch-dist-mnist:latest --workers 2
--gpu-request-type portion --gpu-portion-request 0.1 --gpu-devices-request 1 --cpu-memory-request 100M
This would start a distributed training workload based on kubeflow/pytorch-dist-mnist:latest with one master and two workers.
Copy the following command to your terminal. Make sure to update the below parameters according to the comments. For more details, see Distributed API reference:
curl -L 'https://<COMPANY-URL>/api/v1/workloads/distributed' \ # (1)
-H 'Content-Type: application/json' \
-H 'Authorization: Bearer <TOKEN>' \ # (2)
-d '{
"name": "workload-name",
"projectId": "<PROJECT-ID>", '\ # (3)
"clusterId": "<CLUSTER-UUID>", \ # (4)
"spec": {
"compute": {
"cpuCoreRequest": 0.1,
"gpuRequestType": "portion",
"cpuMemoryRequest": "100M",
"gpuDevicesRequest": 1,
"gpuPortionRequest": 0.1
},
"image": "kubeflow/pytorch-dist-mnist:latest",
"numWorkers": 2, \
"distributedFramework": "PyTorch" \
}
}'
<COMPANY-URL>
is the link to the Run:ai user interface.<TOKEN>
is the API access token obtained in Step 1.<PROJECT-ID>
is #The ID of the Project the workload is running on. You can get the Project ID via the Get Projects API Get Projects API.<CLUSTER-UUID>
is the unique identifier of the Cluster. You can get the Cluster UUID by adding the "Cluster ID" column to the Clusters view.
This would start a distributed training workload based on kubeflow/pytorch-dist-mnist:latest with one master and two workers.
Note
The above API snippet will only work with Run:ai clusters of 2.18 and above. For older clusters, use, the now deprecated Cluster API.
Next Steps¶
- Manage and monitor your newly created workload using the workloads table.
- After validating your training performance and results, deploy your model using inference.