b6044b3489
- Update to Docker CE 19.03.1 - Use "native" Docker/containerd GPU support - Breaking change in jobs configuration to allow arbitrary configuration - Update docs - Resolves #293 |
||
---|---|---|
.. | ||
config | ||
docker | ||
README.md |
README.md
CNTK-GPU-Infiniband-IntelMPI
This recipe shows how to run CNTK on GPUs across Infiniband/RDMA enabled Azure VMs via Intel MPI.
Configuration
Please see refer to this set of sample configuration files for this recipe.
Pool Configuration
The pool configuration should enable the following properties:
vm_size
must be a GPU RDMA-enabled instance.vm_configuration
is the VM configuration. Please select an appropriateplatform_image
with GPU+IB/RDMA as supported by Batch Shipyard.inter_node_communication_enabled
must be set totrue
max_tasks_per_node
must be set to 1 or omitted
Global Configuration
The global configuration should set the following properties:
docker_images
array must have a reference to a valid CNTK GPU-enabled Docker image that can be run with Intel MPI. Images denoted withgpu
andintelmpi
tags found in alfpark/cntk are compatible with Azure VMs with GPUs and RDMA. Images denoted withrefdata
tag suffixes found in alfpark/cntk can be used for this recipe which contains reference data for MNIST and CIFAR-10 examples. If you do not need this reference data then you can use the images without therefdata
suffix on the image tag. For this example,alfpark/cntk:2.1-gpu-1bitsgd-py36-cuda8-cudnn6-intelmpi-refdata
can be used.
MPI Jobs Configuration (MultiNode)
The jobs configuration should set the following properties within the tasks
array which should have a task definition containing:
docker_image
should be the name of the Docker image for this container invocation. For this example, this should bealfpark/cntk:2.1-gpu-1bitsgd-py36-cuda8-cudnn6-intelmpi-refdata
. Please note that thedocker_images
in the Global Configuration should match this image name.multi_instance
property must be definednum_instances
should be set topool_specification_vm_count_dedicated
,pool_specification_vm_count_low_priority
,pool_current_dedicated
, orpool_current_low_priority
coordination_command
should be unset ornull
. For pools withnative
container support, this command should be supplied if a non-standardsshd
is required.resource_files
should be unset or the array can be emptypre_execution_command
should source the cntk activation script and the Intelmpivars.sh
script:source /cntk/activate-cntk; source /opt/intel/compilers_and_libraries/linux/mpi/bin64/mpivars.sh
mpi
property must be definedruntime
should be set tointelmpi
processes_per_node
should be set tonvidia-smi -L | wc -l
command
should contain the command to pass to thempirun
invocation. For this example, we will run the ResNet-20 Distributed training on CIFAR-10 example in thealfpark/cntk:2.1-gpu-1bitsgd-py35-cuda8-cudnn6-refdata
Docker image. The applicationcommand
to run would be:python -u /cntk/Examples/Image/Classification/ResNet/Python/TrainResNet_CIFAR10_Distributed.py --network resnet20 -q 1 -a 0 --datadir /cntk/Examples/Image/DataSets/CIFAR-10 --outputdir $AZ_BATCH_TASK_WORKING_DIR/output
infiniband
can be set totrue
, however, it is implicitly enabled by Batch Shipyard when executing on a RDMA-enabled compute pool.gpus
can be set toall
, however, it is implicitly enabled by Batch Shipyard when executing on a GPU-enabled compute pool and can be omitted.
Dockerfile and supplementary files
Supplementary files can be found here.
You must agree to the following licenses prior to use: