A managed runner is the CoreWeave-managed component that runs sandboxes inside your CKS cluster. This page covers the full lifecycle: deploy a runner, confirm it is healthy, adjust its configuration as your needs change, and remove it when you no longer need it. For where the runner sits in the sandbox architecture and how the gateway brokers requests to it, see Sandboxes architecture.Documentation Index
Fetch the complete documentation index at: https://docs.coreweave.com/llms.txt
Use this file to discover all available pages before exploring further.
CoreWeave sandboxes are in public preview. For access, contact your CoreWeave account team, reach out to CoreWeave Support, or email support@coreweave.com.
Before you begin
Both the CLI and thecurl examples on this page authenticate with a CoreWeave API access token. Generate one from the Tokens page in the cloud console and copy the Token Secret value. For more on tokens, see Manage API access tokens.
CLI: install the CoreWeave Intelligent CLI (cwic), then run cwic auth login and paste the token when prompted. The token is stored in your local cwic config. Subsequent commands read it automatically. You don’t need to set an environment variable.
curl: export the token in your shell so the examples on this page can pick it up:
Runner commands
Thecwic sandbox runner group manages runners. The following table maps each lifecycle task to the command that performs it. Later sections walk through these commands in context.
| Goal | Command |
|---|---|
| Deploy a runner (wizard) | cwic sandbox runner create [RUNNER-ID] |
| Deploy a runner from a file | cwic sandbox runner create [RUNNER-ID] -f runner.yaml |
| List runners | cwic sandbox runner get (alias ls) |
| Inspect one runner | cwic sandbox runner get [RUNNER-ID] |
| Detailed view | cwic sandbox runner describe [RUNNER-ID] |
| Edit a runner | cwic sandbox runner edit [RUNNER-ID] |
| Apply an available update | cwic sandbox runner upgrade [RUNNER-ID] |
| Delete a runner | cwic sandbox runner delete [RUNNER-ID] |
Deploy a runner
Each CKS cluster hosts at most one managed runner. To deploy one, supply:- Runner ID: a client-assigned human-readable ID, unique within your organization.
- Zone: the geographic zone the cluster belongs to.
- Cluster ID (or cluster name): which CKS cluster the runner runs on. You can find both on the Clusters page in the cloud console.
- Profile bindings: at least one binding, with exactly one default. The profile referenced in each binding must already exist.
- CLI
- curl
The wizard collects cluster, profiles, release channel, and maintenance windows interactively, then opens your editor with a pre-filled spec before submitting:File mode accepts YAML or JSON, which makes it the preferred path for repeatable setups and a good fit for agents like Claude Code or Codex that generate runner specs on your behalf. The CLI also reads from stdin with Submit the spec:
-f -.runner.yaml
maintenance_policy.windowsis optional. When set, automatic updates apply only during the specified cron windows.runner_group_idis optional. Use it for scheduling affinity when you have multiple runners in the same zone.
Common validation errors
| Error | Fix |
|---|---|
runner.identity.zone is required | Supply a zone. Find zones where you have a CKS cluster (and therefore quota for a runner) on the Clusters page in the cloud console, or by running cwic cluster get. |
runner.identity.cluster_id or cluster_name is required | Supply one. You can find both on the Clusters page in the cloud console, or by running cwic cluster get. |
one or more profile_bindings reference a template that does not exist | Create the profile first, or double-check the ID by running cwic sandbox profile get [PROFILE-ID] (or cwic sandbox profile get with no args to list all profiles). |
runner cannot have more than one default profile binding | Exactly one binding must be the default. |
a managed runner already exists for this cluster | A cluster hosts at most one managed runner. Update the existing one, or delete it first. |
Check runner status
After creation, check the runner’s status to confirm it rolled out successfully and to diagnose problems if it did not.- CLI
- curl
get:prod-us-east-1) or the server-assigned UUID.installStatus: progress of the runner deployment into your cluster (PENDING,PROVISIONING,READY, orFAILED).connectionStatus: live connectivity (CONNECTEDorDISCONNECTED). The runner’s heartbeat updates this value. Expect up to 30 seconds of lag.
installStatus == FAILED, the response includes a structured installError:
remediationHints are the actions you should take. diagnosticDetail also contains internal logs that are useful to attach if you open a support ticket.
Update a runner
The runner edit command supports both an interactive wizard and a file-driven patch. Internally, updates use a field mask: only the fields you change are applied. Everything else is read-only, includinginstallStatus, connectionStatus, timestamps, and the resolved deployment spec.
The following paths are mutable:
identity.zoneidentity.runner_group_idmanaged_spec(whole object)managed_spec.release_channelmanaged_spec.maintenance_policymanaged_spec.overridesprofile_bindings(whole list)
Common runner updates
The following examples show the most frequent edits applied to a runner: switching release channels, attaching another profile, and tuning where the runner pod lands in your cluster.Example: switch release channel
- CLI
- curl
Apply a one-line patch from stdin:Or write the patch to a file and submit it:
patch.yaml
Example: attach a second profile
profile_bindings is replaced as a whole list. To attach a new profile while you preserve the existing default, send both bindings:
- CLI
- curl
bindings.yaml
profile_template_id. Missing entries are detached, new entries are attached, and changed entries are updated in place, all in one transaction.
Example: pin node placement through deployment overrides
Themanaged_spec.overrides field tunes the runner’s own pod, not sandbox pods. Use it when the runner pod requires specific tolerations, node selectors, or runtime classes to land on the right nodes.
A common case is routing the runner pod through the SUNK Pod Scheduler so it can run in your SUNK cluster alongside Slurm jobs. Set the scheduler name and the SUNK annotations on the runner overrides. See SUNK Pod Scheduler integration for the available annotations and required setup.
- CLI
- curl
overrides.yaml
Trigger an on-demand runner update
WhenupdateAvailable is true on the runner, you can apply the update immediately rather than wait for the next maintenance window:
- CLI
- curl
target_revision. The in-cluster controller rolls it out.
List runners
To see every runner in your organization, or to narrow the view to a specific zone, cluster, or connection state, use the following list commands.- CLI
- curl
Delete a runner
Remove a runner when you no longer need sandbox capacity on its cluster, or before you redeploy a fresh runner on the same cluster.- CLI
- curl
--yes to skip the prompt for scripted use:See also
- Sandboxes architecture: the four-resource taxonomy, control plane compared to data plane, and multi-cluster topology.
- Understanding profiles: how profiles, bindings, and overrides combine at sandbox launch.
- Configure a sandbox profile:
cwicworkflow plus field-by-field walkthrough of the profile spec. - Control plane API overview: authentication, field masks, and the request and response shapes for every endpoint.
- Profile reference: every field you can set on a profile.