-c, --config: configuration file path--session: explicit session identifier--owner: owner label override (default:OKDEV_OWNERor localUSER)-n, --namespace: namespace override--context: kubeconfig context override. When omitted,spec.kubeContextis used if set; otherwise kubeconfig current-context is used.--output text|json: output format (list,status)--verbose: debug loggingNO_COLOR=1orTERM=dumb: disable ANSI color/styling in interactive terminal output
okdev versionokdev init [--workload pod|job|pytorchjob|generic] [--dev-image <image>] [--template <name>|<path>|<url>] [--set key=value] [--stignore-preset default|python|node|go|rust] [--force]okdev template list [--all]okdev template show <name>okdev validateokdev up [--wait-timeout 10m] [--dry-run]okdev down [session] [--delete-pvc] [--dry-run] [--wait] [--wait-timeout 2m] [--output json]okdev status [session] [--all] [--all-users] [--details]okdev list [--all-namespaces] [--all-users]okdev use <session>okdev target showokdev target set [--pod <name> | --role <role>]okdev agent listokdev exec [session] [--shell /bin/bash] [--no-tty] [--pod <name> | --role <role> | --label <k=v>] [--exclude <pod>] [--container <name>] [--detach] [--timeout <duration>] [--log-dir <path>] [--no-prefix] [--fanout N] [-- command...]okdev cp [session] <src> <dst> [--all | --pod <name> | --role <role> | --label <k=v>] [--exclude <pod>] [--container <name>] [--fanout N]okdev logs [session] [--container <name> | --all] [--tail N] [--since 5m] [--follow] [--previous]okdev ssh [session] [--setup-key] [--user root] [--cmd "..."] [--no-tmux] [--forward-agent|--no-forward-agent]okdev portsokdev sync [--mode up|down|bi] [--foreground] [--reset] [--dry-run]okdev prune [--ttl-hours 72] [--all-namespaces] [--all-users] [--include-pvc] [--dry-run]okdev migrate [--template <name>] [--set key=value] [--dry-run] [--yes]okdev upgrade
- Shows session status for the current or selected session.
- When
sessionis provided,okdevcan resolve the saved config from session metadata even outside the repo. --details: prints a single-session diagnostic view with target selection, pod list, managed SSH state, sync state, key local paths, and target pod details.--detailsis only valid when exactly one session is selected.
- Prints the pinned interactive target for the current session and shows the session pod set.
- The selected row is marked with
*.
- Explicitly repins the interactive target used by
ssh,exec,ports, and sync. --podselects one concrete session pod.--roleselects the highest-priority eligible pod with the matchingokdev.io/workload-role.- When attachable pods are defined, repinning is restricted to those pods.
- Shows configured coding agents, whether their CLI binary is installed, and whether auth is staged in the current session container.
okdev upperforms best-effort install checks for configured agents, bootstraps a modern Node/npm runtime vianvmwhen supported, and then installs missing CLIs.okdev upalso stages local auth files for dedicated sessions when a configured local auth file exists.- Codex uses
~/.codex/auth.jsonby default, butspec.agents[].auth.localPathcan point at a different local auth file. okdev downremoves staged agent auth symlinks/runtime files when it can still reach the target container.okdevdoes not own agent process launch; users runcodex,claude,gemini,opencode, or similar CLIs manually after connecting.
- Opens a shell or runs a command in one or more session pods.
- Without
-- command..., opens an interactive shell on the pinned target pod. - With
-- command..., runs the command across all running pods by default, with output prefixed by short pod name. --pod: target specific pods by name (repeatable or comma-separated).--role: target pods byokdev.io/workload-rolelabel (case-insensitive).--label: target pods by arbitrary labelkey=value(repeatable, AND logic).--exclude: exclude specific pods from the selected set (repeatable or comma-separated). Cannot be used with--pod.--container: override which container to exec into (default: session target container). Works in both modes.--detach: wrap the command innohupand return immediately. Prints per-pod confirmation.--timeout: per-pod command timeout (e.g.,30s,5m). Pods exceeding the timeout are cancelled and reported as failed.--log-dir: write per-pod output to<dir>/<short-name>.log. Streaming to stdout still happens.--no-prefix: suppress the pod name prefix in output. Useful when targeting a single pod or piping.--fanout N: maximum concurrent pod executions (default 16).--pod,--role, and--labelare mutually exclusive.
- Copies files or directories between the local machine and session pods.
- Prefix the remote path with
:(e.g.,:/workspace/data). The other argument is a local path. - Single-pod mode (default): copies to/from the pinned target pod.
- Multi-pod upload (
--all,--pod,--role,--label): fans out the same local source to all matched pods in parallel. - Multi-pod download: downloads from each matched pod into
<dest>/<short-pod-name>/subdirectories. - Files are streamed via
catpipes. Directories are tar-streamed automatically. --all: target all running pods in the session.--pod: target specific pods by name (repeatable or comma-separated).--role: target pods byokdev.io/workload-rolelabel (case-insensitive).--label: target pods by arbitrary labelkey=value(repeatable, AND logic).--exclude: exclude specific pods from the selected set (repeatable or comma-separated). Cannot be used with--pod.--container: override which container to copy to/from (default: session target container).--fanout N: maximum concurrent pod transfers (default 16).--all,--pod,--role, and--labelare mutually exclusive.
okdev init [--workload pod|job|pytorchjob|generic] [--template <name>|<path>|<url>] [--set key=value] [--stignore-preset default|python|node|go|rust] [--force]
- Writes a starter config manifest.
- Pod-only setups default to
.okdev.yaml. - When built-in workload scaffolding also writes files under
.okdev/, the config is written as.okdev/okdev.yaml. --workload: chooses the scaffold mode.podkeeps the current simple config shape;jobandpytorchjobadd aspec.workloadblock plus a starter manifest;genericrequires explicit inject information and can optionally use a preset such as--generic-preset deployment.--dev-image: sets the dev container image for pod workloads. Pod configs generated from the built-in template include apodTemplatewith the dev container image plus equal CPU/memory requests and limits for the dev container and sidecar, so the starter pod is eligible for KubernetesGuaranteedQoS.--template: accepts a project template from.okdev/templates/<name>.yaml.tmpl, a user template from~/.okdev/templates/<name>.yaml.tmpl, built-inbasic, a file path, or a URL. Runokdev template listto see available names.--set: sets a frontmatter-declared template variable. Repeat it for multiple variables, for example--set numWorkers=4 --set baseImage=pytorch:latest.- Templates can declare
string,int, andboolvariables in YAML frontmatter. Resolved values are available as.Vars.<name>during rendering and are persisted underspec.template.vars. - Templates can also declare companion
filesin frontmatter. Each file has a renderedpathand atemplatepath resolved relative to the selected template, which lets a PyTorch template render bothokdev.yamland a matchingpytorchjob.yaml. - For built-in templates, it also writes a starter local
.stignorefile for the initialized sync root. - For built-in
basic,jobandpytorchjobscaffold.okdev/job.yamlor.okdev/pytorchjob.yaml. When the config itself is.okdev/okdev.yaml, the generatedmanifestPathstays relative to that directory, for examplejob.yamlorpytorchjob.yaml. okdev resolves those paths from.okdev/first and falls back to the project root for compatibility with older layouts.generic --generic-preset deploymentscaffolds.okdev/deployment.yamlwhile still usingspec.workload.type=generic. --stignore-preset: override the starter.stignorepatterns with a project-oriented preset.- When
--stignore-presetis omitted,okdev inittries to detect a preset from common repo markers likego.mod,package.json,Cargo.toml, andpyproject.toml.
- Lists templates from project, user, and built-in sources in resolution order.
- Project templates in
.okdev/templates/shadow user templates, and user templates shadow built-ins. --allincludes shadowed lower-priority entries.
- Prints a template's resolved source, description, declared companion files, and declared variables.
- Description and variables come from optional YAML frontmatter at the top of the template.
- Without
--template, migrates older config schema fields to the current schema. - With
--template, re-renders the selected template, overlays existing config values so local edits win, and writes the merged config. - Existing
spec.template.varsseed template variables during migration;--setoverrides stored values. --dry-runprints the merged config without writing.--yesskips confirmation when writing.
- Reconciles Pod/PVC resources, updates SSH config, initializes managed forwarding/sync, then exits.
- If the session workload already exists,
okdev upreuses it and only reruns setup. - Workload resources are named per run, for example
okdev-<session>-<run-id>;okdev down && okdev upcreates a fresh workload name for the same session. - tmux-backed persistent interactive shells are enabled by default.
--tmux: explicitly enable tmux mode in the dev container.--no-tmux: disable tmux mode for this pod.- When
sync.engine=syncthing,okdev uprefreshes the session's local Syncthing processes, starts background sync in bidirectional mode by default, and waits for the initial sync to converge before exiting. spec.portsis materialized as SSHLocalForwardorRemoteForwardbased ondirection.
- Deletes the current session workload and cleans up local SSH/sync metadata.
- When
sessionis provided,okdevcan resolve the saved config from session metadata even outside the repo. - Prompts for confirmation by default; use
--yesin scripts or non-interactive environments. --dry-run: previews what would be deleted without removing cluster or local state.--wait: waits for the workload object to disappear and then for any remaining session pods to terminate before returning.--wait-timeout: caps the total time spent waiting for workload/pod termination when--waitis enabled.--output json: emits a machine-readable summary of the planned or completed deletion and local cleanup steps.--delete-pvcremains accepted for compatibility but is ignored;okdevno longer manages PVC lifecycle automatically.
okdev ssh [session] [--setup-key] [--user root] [--cmd "..."] [--no-tmux] [--forward-agent|--no-forward-agent]
- Targets
okdev-sshdin the resolved interactive container. - The default interactive container name is
dev; override it withspec.workload.attach.containerwhen your workload uses a different main container name. - When
sessionis provided,okdevcan resolve the saved config from session metadata even outside the repo. - Maintains managed host alias in
~/.ssh/configasokdev-<session>. --no-tmux: bypass tmux for this SSH session when tmux mode is enabled.--forward-agent: forwards the localSSH_AUTH_SOCKinto the live SSH session so Git/SSH inside the workload can use your local agent.--no-forward-agent: disables forwarding for this SSH session even whenspec.ssh.forwardAgent: true.- Agent forwarding only applies to the live
okdev sshconnection; keys are not copied into the workload. - Requires a local SSH agent with identities already loaded, for example
eval "$(ssh-agent -s)"andssh-add ~/.ssh/id_ed25519.
- Streams logs from the resolved target pod for the current session.
- When
sessionis provided,okdevcan resolve the saved config from session metadata even outside the repo. - Defaults to the pinned target container when
--containeris omitted. - The default target container name is
devunlessspec.workload.attach.containerselects a different interactive container. --all: streams all regular containers in the target pod and prefixes each line with[container].--follow: follows logs by default; use--follow=falsefor a bounded dump.--tailand--sincemirror the usual Kubernetes log filters.--previous: reads the previous instance logs for the selected container(s).
- Advanced/recovery command. Rebuilds managed SSH
LocalForward/RemoteForwardstate fromspec.portsafter disconnects or local port changes. - No-op when managed forwards are already healthy and config is unchanged.
--dry-run: previews the SSH alias and port-forward actions without updating SSH config or starting/stopping managed forwards.
- Advanced command. Starts detached background sync by default; use
--foregroundfor sync debugging, or explicit one-way sync (up/down). - For default
--mode bi, no-op when background sync is already active for the session. --background: explicitly request detached background mode.--reset: check local-to-hub sync and mesh receiver health, then reset only what is broken. Skips the local sync teardown when the primary sync is already healthy. For sessions with mesh receivers, probes each receiver and re-runs mesh setup only when broken or disconnected receivers are found.--reset --force/--reset -f: unconditionally reset without health checks.--reset --local: scope reset to local-to-hub sync only (skip mesh).--reset --mesh: scope reset to mesh receivers only (skip local sync).--reset --force --local/--reset --force --mesh: force reset a specific component.okdev initwrites the starter config and, for built-in templates, a starter local.stignorefile for the initialized sync root.
- Checks the latest GitHub release and upgrades the
okdevbinary in place. - Downloads the correct archive for the current OS/architecture, verifies the SHA256 checksum, and atomically replaces the running binary.
- No-op when already on the latest version.
- After
okdev upcompletes successfully, a non-blocking version check runs (cached for 24 hours) and prints a reminder to stderr if a newer version is available.