holodeck

module
v0.3.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 27, 2026 License: Apache-2.0

README ΒΆ

Holodeck

Latest Release

CI Pipeline

A tool for creating and managing GPU-ready Cloud test environments.


πŸ“– Documentation


✨ Features

  • Multi-OS Support: Ubuntu, Rocky Linux 9, Amazon Linux 2023 with automatic AMI resolution (guide)
  • Multi-Architecture: x86_64 and ARM64 with automatic architecture inference
  • Custom Templates: Run user-provided scripts at any provisioning phase (guide)
  • Multi-Node Clusters: HA Kubernetes clusters with kubeadm (guide)
  • Flexible Sources: Install components from packages, git, runfiles, or latest branches (guide)
  • Automatic IP Detection: No manual IP configuration needed for AWS (guide)

πŸš€ Quick Start

See docs/quick-start.md for a full walkthrough.

Install via Homebrew (macOS, Linux)
brew tap nvidia/holodeck https://github.com/NVIDIA/holodeck
brew install nvidia/holodeck/holodeck
holodeck --help

Pre-built binaries for macOS (arm64, amd64) and Linux (arm64, amd64) are downloaded from the GitHub Releases page. Run brew upgrade nvidia/holodeck/holodeck to update.

Install from source
make build
sudo mv ./bin/holodeck /usr/local/bin/holodeck
holodeck --help

πŸ› οΈ Prerequisites

  • Go 1.20+
  • (For AWS) Valid AWS credentials in your environment
  • (For SSH) Reachable host and valid SSH key

See docs/prerequisites.md for details.


⚠️ Important: Kernel Compatibility

When installing NVIDIA drivers, Holodeck requires kernel headers matching your running kernel version. If exact headers are unavailable, Holodeck will attempt to find compatible ones, though this may cause driver compilation issues.

For kernel compatibility details and troubleshooting, see Kernel Compatibility in the prerequisites documentation.


πŸ“ How to Contribute

See docs/contributing/ for full details.

Main Makefile Targets
  • make build – Build the holodeck binary
  • make test – Run all tests
  • make lint – Run linters
  • make clean – Remove build artifacts

πŸ§‘β€πŸ’» Usage

See docs/commands/ for detailed command documentation and examples.

holodeck --help
Example: Create an environment
holodeck create -f ./examples/v1alpha1_environment.yaml
Example: List environments
holodeck list
Example: Delete an environment
holodeck delete <instance-id>
Example: Clean up AWS VPC resources
holodeck cleanup vpc-12345678
Example: Check status
holodeck status <instance-id>
Example: Dry Run
holodeck dryrun -f ./examples/v1alpha1_environment.yaml
Remote-access kubeconfig (opt-in)

By default, the kubeconfig holodeck produces is configured for in-VM use: file mode 0600 owned by the holodeck process user, and the server URL points at the cluster's internal IP. To run kubectl from outside the VPC (e.g., a GitHub Actions runner that provisioned the cluster), set kubernetes.remoteAccess: true:

spec:
  kubernetes:
    install: true
    installer: kubeadm
    remoteAccess: true

What changes when this is true:

  • The kubeconfig server URL is rewritten to https://<PublicDnsName>:6443.
  • The kubeconfig file is chowned to the bind-mounted workspace owner so the runner user (not just the action container's root) can read it. File mode stays 0600.

What does not change:

  • The security group still opens 6443 only to the auto-detected caller egress IP (utils.GetIPAddress()), not 0.0.0.0/0.
  • The embedded cluster admin cert is owner-only.

Platform: Linux/Darwin. On Windows, the chown step is a no-op.

For downstream CI repos (gpu-operator, k8s-device-plugin): set remoteAccess: true in your holodeck.yaml and replace any rsync + ssh + remote-run blocks in your workflow with a direct kubectl --kubeconfig=$GITHUB_WORKSPACE/kubeconfig … step.

Agentic skills

Holodeck ships an embedded catalog of agentic skills that teach an AI coding agent how to drive the CLI correctly. List the catalog:

holodeck skill list

Install a skill into your AI agent's native format:

# Claude Code (project-local: ./.claude/skills/<name>/SKILL.md)
holodeck skill add --claude using-holodeck

# Multiple agents at once
holodeck skill add --claude --cursor --codex --gemini using-holodeck

# Or install everything for every agent, user-wide
holodeck skill add --all --all-agents --global

Supported agents: Claude Code, Cursor, Codex CLI, Gemini CLI. Skills are short markdown guides authored against the actual CLI behavior; they version with the code so updates land alongside the features they describe.

πŸ“‚ More


For more information, see the documentation directory.

Directories ΒΆ

Path Synopsis
api
holodeck/v1alpha1
Package v1alpha1 contains API Schema definitions for the holodeck v1alpha1 API group +kubebuilder:object:generate=true +groupName=holodeck.nvidia.com
Package v1alpha1 contains API Schema definitions for the holodeck v1alpha1 API group +kubebuilder:object:generate=true +groupName=holodeck.nvidia.com
cmd
action command
cli command
cli/os
Package os provides CLI commands for managing operating system images.
Package os provides CLI commands for managing operating system images.
cli/skill
Package skill exposes the `holodeck skill` CLI command, which lists and installs the embedded agentic skill catalog.
Package skill exposes the `holodeck skill` CLI command, which lists and installs the embedded agentic skill catalog.
internal
ami
Package ami provides internal AMI-to-OS mapping utilities for holodeck.
Package ami provides internal AMI-to-OS mapping utilities for holodeck.
aws
Package aws provides internal AWS utilities and interfaces for the holodeck project.
Package aws provides internal AWS utilities and interfaces for the holodeck project.
pkg
skill
Package skill provides the holodeck agentic-skill catalog: parsing, rendering for each agent target, and installation.
Package skill provides the holodeck agentic-skill catalog: parsing, rendering for each agent target, and installation.
testutil
Package testutil provides shared testing utilities, fixtures, and mocks for the holodeck test suite.
Package testutil provides shared testing utilities, fixtures, and mocks for the holodeck test suite.
testutil/mocks
Package mocks provides mock implementations for external dependencies used in testing.
Package mocks provides mock implementations for external dependencies used in testing.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL