π£ The NVIDIA Run:ai docs are moving!
Weβve launched a new documentation site to improve navigation, clarity, and access to the latest features starting from NVIDIA Run:ai v2.20 and above. Visit NVIDIA Run:ai documentation.
Documentation for versions 2.19 and below will remain on this site.
OverviewΒΆ
Run:ai is a GPU orchestration and optimization platform that helps organizations maximize compute utilization for AI workloads. By optimizing the use of expensive compute resources, Run:ai accelerates AI development cycles, and drives faster time-to-market for AI-powered innovations.
Built on Kubernetes, Run:ai supports dynamic GPU allocation, workload submission, workload scheduling, and resource sharing, ensuring that AI teams get the compute power they need while IT teams maintain control over infrastructure efficiency.
How Run:ai helps your organizationΒΆ
For infrastructure administratorsΒΆ
Run:ai centralizes cluster management and optimizes infrastructure control by offering:
- Centralized cluster management β Manage all clusters from a single platform, ensuring consistency and control across environments.
- Usage monitoring and capacity planning β Gain real-time and historical insights into GPU consumption across clusters to optimize resource allocation and plan future capacity needs efficiently.
- Policy enforcement β Define and enforce security and usage policies to align GPU consumption with business and compliance requirements.
- Enterprise-grade authentication β Integrate with your organization's identity provider for streamlined authentication (Single Sign On) and role-based access control (RBAC).
- Kubernetes-native application β Install as a Kubernetes-native application, seamlessly extending Kubernetes for native cloud experience and operational standards (install, upgrade, configure).
For platform administratorsΒΆ
Run:ai simplifies AI infrastructure management by providing a structured approach to managing AI initiatives, resources, and user access. It enables platform administrators maintain control, efficiency, and scalability across their infrastructure:
- AI Initiative structuring and management β Map and set up AI initiatives according to your organization's structure, ensuring clear resource allocation.
- Centralized GPU resource management β Enable seamless sharing and pooling of GPUs across multiple users, reducing idle time and optimizing utilization.
- User and access control β Assign users (AI practitioners, ML engineers) to specific projects and departments to manage access and enforce security policies, utilizing role-based access control (RBAC) to ensure permissions align with user roles.
- Workload scheduling β Use scheduling to prioritize and allocate GPUs based on workload needs.
- Monitoring and insights β Track real-time and historical data on GPU usage to help track resource consumption and optimize costs.
For AI practitionersΒΆ
Run:ai empowers data scientists and ML engineers by providing:
- Optimized workload scheduling β Ensure high-priority jobs get GPU resources. Workloads dynamically receive resources based on demand.
- Fractional GPU usage β Request and utilize only a fraction of a GPU's memory, ensuring efficient resource allocation and leaving room for other workloads.
- AI initiatives lifecycle support β Run your entire AI initiatives lifecycle β Jupyter Notebooks, training jobs, and inference workloads efficiently.
- Interactive session β Ensure an uninterrupted experience when working on Jupyter Notebooks without taking away GPUs.
- Scalability for training and inference β Support for distributed training across multiple GPUs and auto-scales inference workloads.
- Integrations β Integrate with popular ML frameworks - PyTorch, TensorFlow, XGBoost, Knative, Spark, Kubeflow Pipelines, Apache Airflow, Argo workloads, Ray and more.
- Flexible workload submission β Submit workloads using the Run:ai UI, API, CLI or run third-party workloads.
Run:ai system componentsΒΆ
Run:ai is made up of two components both installed over a Kubernetes cluster:
- Run:ai cluster β Provides Scheduling and workload management, extending Kubernetes native capabilities.
- Run:ai control plane β Provides resource management, handles workload submission and provides cluster monitoring and analytics.
Run:ai clusterΒΆ
The Run:ai cluster is responsible for scheduling AI workloads and efficiently allocating GPU resources across users and projects:
- Run:ai Scheduler β Applies AI-aware rules to efficiently schedule workloads submitted by AI practitioners.
- Workload management β Handles workload management which includes the researcher code running as a Kubernetes container and the system resources required to run the code, such as storage, credentials, network endpoints to access the container and so on.
- Kubernetes operator-based deployment β Installed as a Kubernetes Operator to automate deployment, upgrades and configuration of Run:ai cluster services.
- Storage β Supports Kubernetes-native storage using Storage Classes, allowing organizations to bring their own storage solutions. Additionally, it also integrates with external storage solutions such as Git, S3, and NFS to support various data requirements.
- Secured communication β Uses an outbound-only, secured (SSL) connection to synchronize with the Run:ai control plane.
- Private β Run:ai only synchronizes metadata and operational metrics (e.g., workloads, nodes) with the control plane. No proprietary data, model artifacts, or user data sets are ever transmitted, ensuring full data privacy and security.
Run:ai control planeΒΆ
The Run:ai control plane provides a centralized management interface for organizations to oversee their GPU infrastructure across multiple locations/subnets, accessible via Web UI, API and CLI. The control plane can be deployed on the cloud or on-premise for organizations that require local control over their infrastructure - self-hosted. Self-hosted installation supports both connected and air-gapped. See self-hosted installation for more details.
- Multi-cluster management β Manages multiple Run:ai clusters for a single tenant across different locations and subnets from a single unified interface.
- Resource and access management β Allows administrators to define Projects, Departments and user roles, enforcing policies for fair resource distribution.
- Workload submission and monitoring β Allows teams to submit workloads, track usage, and monitor GPU performance in real time.
