runai submit-mpi
Description¶
Submit a Distributed Training (MPI) Run:ai Job for execution.
Note
To use distributed training you need to have installed the Kubeflow MPI Operator as specified here
Synopsis¶
runai submit-mpi
[--attach]
[--backoff-limit int]
[--command]
[--cpu double]
[--cpu-limit double]
[--create-home-dir]
[--environment stringArray | -e stringArray]
[--git-sync string]
[--gpu double | -g double]
[--gpu-memory string]
[--host-ipc]
[--host-network]
[--image string | -i string]
[--interactive]
[--job-name-prefix string]
[--large-shm]
[--local-image]
[--memory string]
[--memory-limit string]
[--mount-propagation]
[--name string]
[--node-pool string]
[--node-type string]
[--prevent-privilege-escalation]
[--processes int]
[--pvc [StorageClassName]:Size:ContainerMountPath:[ro]]
[--run-as-user]
[--s3 string]
[--stdin]
[--toleration string]
[--tty | -t]
[--volume stringArray | -v stringArray]
[--nfs-server string]
[--working-dir]
[--loglevel string]
[--project string | -p string]
[--help | -h]
-- [COMMAND] [ARGS...] [options]
- Options with a value type of stringArray mean that you can add multiple values. You can either separate values with a comma or add the flag twice.
Examples¶
start an unattended mpi training Job of name dist1, based on Project team-a using a quickstart-distributed image:
runai submit-mpi --name dist1 --processes=2 -g 1 \
-i gcr.io/run-ai-demo/quickstart-distributed:v0.3.0 -e RUNAI_SLEEP_SECS=60
(see: distributed training Quickstart).
Options¶
Aliases and Shortcuts¶
--name¶
The name of the Job.
--interactive¶
Mark this Job as Interactive. Interactive Jobs are not terminated automatically by the system.
--job-name-prefix string¶
The prefix to use to automatically generate a Job name with an incremental index. When a Job name is omitted Run:ai will generate a Job name. The optional
--job-name-prefix flag
creates Job names with the provided prefix.
Container Related¶
--attach¶
Default is false. If set to true, wait for the Pod to start running. When the pod starts running, attach to the Pod. The flag is equivalent to the command runai attach.
The --attach flag also sets
--tty
and--stdin
to true.
--command¶
Overrides the image's entry point with the command supplied after '--'. When not using the
--command
flag, the entry point will not be overrided and the string after--
will be appended as arguments to the entry point command.Example:
--command -- run.sh 1 54
will start the docker and runrun.sh 1 54
-- script.py 10000
will augmentscript.py 10000
to the entry point command (e.g.python
)
-e stringArray | --environment stringArray¶
Define environment variables to be set in the container. To set multiple values add the flag multiple times (
-e BATCH_SIZE=50 -e LEARNING_RATE=0.2
).
--git-sync string¶
Clone a git repository into the container running the Job. The parameter should follow the syntax:
source=REPOSITORY,branch=BRANCH_NAME,rev=REVISION,username=USERNAME,password=PASSWORD,target=TARGET_DIRECTORY_TO_CLONE
.Note that source and target fields are mandatory.
--image string | -i string¶
Image to use when creating the container for this Job
--image-pull-policy string¶
Pulling policy of the image When starting a container. Options are:
Always
(default): force image pulling to check whether local image already exists. If the image already exists locally and has the same digest, then the image will not be downloaded.IfNotPresent
: the image is pulled only if it is not already present locally.Never
: the image is assumed to exist locally. No attempt is made to pull the image.For more information see Kubernetes documentation.
--local-image (deprecated)¶
Deprecated. Please use
image-pull-policy=never
instead. Use a local image for this Job. A local image is an image that exists on all local servers of the Kubernetes Cluster.
--stdin¶
Keep stdin open for the container(s) in the pod, even if nothing is attached.
-t, --tty
Allocate a pseudo-TTY
--working-dir string¶
Starts the container with the specified directory as the current directory.
Resource Allocation¶
--cpu double¶
CPU units to allocate for the Job (0.5, 1, .etc). The Job will receive at least this amount of CPU. Note that the Job will not be scheduled unless the system can guarantee this amount of CPUs to the Job.
--cpu-limit double¶
Limitations on the number of CPUs consumed by the Job (0.5, 1, .etc). The system guarantees that this Job will not be able to consume more than this amount of CPUs.
--gpu double | -g double¶
Number of GPUs to allocate for the Job. The default is no allocated GPUs. the GPU value can be an integer or a fraction between 0 and 1.
--gpu-memory¶
GPU memory to allocate for this Job (1G, 20M, .etc). The Job will receive this amount of memory. Note that the Job will not be scheduled unless the system can guarantee this amount of GPU memory to the Job.
--large-shm¶
Mount a large /dev/shm device. An shm is a shared file system mounted on RAM.
--memory string¶
CPU memory to allocate for this Job (1G, 20M, .etc). The Job will receive at least this amount of memory. Note that the Job will not be scheduled unless the system can guarantee this amount of memory to the Job.
--memory-limit string¶
CPU memory to allocate for this Job (1G, 20M, .etc). The system guarantees that this Job will not be able to consume more than this amount of memory. The Job will receive an error when trying to allocate more memory than this limit.
Storage¶
--pvc [Storage_Class_Name]:Size:Container_Mount_Path:[ro]
¶
--pvc Pvc_Name:Container_Mount_Path:[ro]
¶
Mount a persistent volume claim into a container.
The 2 syntax types of this command are mutually exclusive. You can either use the first or second form, but not a mixture of both.
Storage_Class_Name is a storage class name that can be obtained by running
kubectl get storageclasses.storage.k8s.io
. This parameter may be omitted if there is a single storage class in the system, or you are using the default storage class.Size is the volume size you want to allocate. See Kubernetes documentation for how to specify volume sizes
Container_Mount_Path. A path internal to the container where the storage will be mounted
Pvc_Name. The name of a pre-existing Persistent Volume Claim to mount into the container
Examples:
--pvc :3Gi:/tmp/john:ro
- Allocate3GB
from the default Storage class. Mount it to/tmp/john
as read-only
--pvc my-storage:3Gi:/tmp/john:ro
- Allocate3GB
from themy-storage
storage class. Mount it to /tmp/john as read-only
--pvc :3Gi:/tmp/john
- Allocate3GB
from the default storage class. Mount it to/tmp/john
as read-write
--pvc my-pvc:/tmp/john
- Use a Persistent Volume Claim namedmy-pvc
. Mount it to/tmp/john
as read-write
--pvc my-pvc-2:/tmp/john:ro
- Use a Persistent Volume Claim namedmy-pvc-2
. Mount it to/tmp/john
as read-only
--volume 'Source:Container_Mount_Path:[ro]:[nfs-host]'¶
Volumes to mount into the container.
Examples:
-v /raid/public/john/data:/root/data:ro
Mount /root/data to local path /raid/public/john/data for read-only access.
-v /public/data:/root/data::nfs.example.com
Mount /root/data to NFS path /public/data on NFS server nfs.example.com for read-write access.
--nfs-server string¶
Use this flag to specify a default NFS host for --volume flag. Alternatively, you can specify NFS host for each volume individually (see --volume for details).
--mount-propagation¶
The flag allows for sharing volumes mounted by a container to other containers in the same pod, or even to other pods on the same node. When the flag is set, Run:ai will set mount propagation to the value of
HostToContainer
as documented here. WithHostToContainer
the volume mount will receive all subsequent mounts that are mounted to this volume or any of its subdirectories.
--git-sync string¶
Clone a git repository into the container running the job. The parameter should follow the syntax:
source=REPOSITORY,branch=BRANCH_NAME,rev=REVISION,username=USERNAME,password=PASSWORD,target=TARGET_DIRECTORY_TO_CLONE
Note that source and target fields are mandatory.
--s3 string¶
Mount an S3 compatible storage into the container running the job. The parameter should follow the syntax:
bucket=BUCKET,key=KEY,secret=SECRET,url=URL,target=TARGET_PATH
All the fields, except url=URL, are mandatory. Default for url is
url=https://s3.amazon.com
Network¶
--host-ipc¶
Use the host's ipc namespace. Controls whether the pod containers can share the host IPC namespace. IPC (POSIX/SysV IPC) namespace provides separation of named shared memory segments, semaphores, and message queues. Shared memory segments are used to accelerate inter-process communication at memory speed, rather than through pipes or the network stack.
For further information see docker run reference documentation.
--host-network¶
Use the host's network stack inside the container. For further information see docker run referencedocumentation.
Job Lifecycle¶
--backoff-limit int¶
The number of times the Job will be retried before failing. The default is 6. This flag will only work with training workloads (when the
--interactive
flag is not specified).
--processes int¶
Number of distributed training processes. The default is 1.
Access Control¶
--create-home-dir¶
Create a temporary home directory for the user in the container. Data saved in this directory will not be saved when the container exits. For more information see non root containers.
--prevent-privilege-escalation¶
Prevent the Job’s container and all launched processes from gaining additional privileges after the Job starts. Default is
false
. For more information see non root containers.
--run-as-user¶
Run in the context of the current user running the Run:ai command rather than the root user. While the default container user is root (same as in Docker), this command allows you to submit a Job running under your Linux user. This would manifest itself in access to operating system resources, in the owner of new folders created under shared directories, etc. Alternatively, if your cluster is connected to Run:ai via SAML, you can map the container to use the Linux UID/GID which is stored in the organization's directory. For more information see non root containers.
Scheduling¶
--node-type string¶
Allows defining specific Nodes (machines) or a group of Nodes on which the workload will run. To use this feature your Administrator will need to label nodes as explained here: Limit a Workload to a Specific Node Group.
This flag can be used in conjunction with Project-based affinity. In this case, the flag is used to refine the list of allowable node groups set in the Project. For more information see: Working with Projects.
--node-pools string¶
Instructs the scheduler to run this workload using specific set of nodes which are part of a Node Pool. You can specify one or more node pools to form a prioritized list of node pools that the scheduler will use to find one node pool that can provide the workload's specification. To use this feature your Administrator will need to label nodes as explained here: Limit a Workload to a Specific Node Group or use existing node labels, then create a node-pool and assign the label to the node-pool. This flag can be used in conjunction with node-type and Project-based affinity. In this case, the flag is used to refine the list of allowable node groups set from a node-pool. For more information see: Working with Projects.
--toleration string¶
Specify one or more toleration criteria, to ensure that the workload is not scheduled onto an inappropriate node. This is done by matching the workload tolerations to the taints defined for each node. For further details see Kubernetes Taints and Tolerations Guide.
The format of the string:
Global Flags¶
--loglevel (string)¶
Set the logging level. One of: debug | info | warn | error (default "info")
--project | -p (string)¶
Specify the Project to which the command applies. Run:ai Projects are used by the scheduler to calculate resource eligibility. By default, commands apply to the default Project. To change the default Project use
runai config project <project-name>
.
--help | -h¶
Show help text.
Output¶
The command will attempt to submit an mpi Job. You can follow up on the Job by running runai list jobs
or runai describe job <job-name>
.
See Also¶
- See Quickstart document Running Distributed Training.
Created: 2023-03-26