CLI Reference
Thunder Compute provides managed instances that are optimized for performance. The Thunder Compute CLI contains all of the functionality you need to create, edit, use, and delete these instances.
Account Management
Login
Authenticate the CLI, which provides a link to the console where you can generate an API token.
Under the hood, this generates and saves an API token to ~/.thunder/token
. You can store a token file here to programmatically authenticate, or by setting the TNR_API_TOKEN
environment variable in your shell.
Logout
Log out of the CLI with:
This deletes the stored API token.
API Token Management
- Generate/manage tokens in the console
- Tokens never expire but can be revoked
- Use unique tokens per device
Managing Instances
Create an Instance
Create a new Thunder Compute instance:
This creates a new instance with default configuration and automatically assigns an instance ID.
CPU Configuration
Configure custom vCPU count:
Each vCPU comes with 4GB of RAM. For example, a 4 core instance has 16GB of RAM, and an 8 core instance has 32GB of RAM.
By default, 4 vCPUs are included with your instance. Additional vCPUs are billed hourly at the rates shown here
GPU Configuration
Specify a GPU type:
Available GPU types:
t4
: NVIDIA T4 (16GB VRAM) - Best for most ML workloadsa100
(default): NVIDIA A100 (40GB VRAM) - For large models and high-performance computinga100xl
: NVIDIA A100 (80GB VRAM) - For even larger models, the biggest and the best
You can use the --num-gpus
flag to specify multiple GPU configurations:
Template Configuration
Templates make it easy to quickly launch common AI tools. Your instance will already be configured with everything you need to get running to generate images, run an LLM, and more.
To use a template, add the --template
flag when creating an instance:
Available templates:
ollama
: Ollama server environmentcomfy-ui
: ComfyUI for AI image generationwebui-forge
: WebUI Forge for Stable Diffusion
After instance creation, start the server using start-<template_name>
when connected. For example:
Stop an Instance
Stops a running instance.
Start an Instance
Starts a stopped instance.
Delete an Instance
This action permanently removes an instance and all associated data.
Using instances
Connect to an Instance
Use the connect
command to access your instance. This wraps SSH, managing keys while automatically setting up everything you need to get started.
The instance must be running before you can connect to it. See if the instance is running and get the instance ID (default 0
) with tnr status
.
Port Forwarding
Connect with port forwarding with the -t
or --tunnel
flag:
Features:
- Forward multiple ports using repeated
-t/--tunnel
flags - Example:
tnr connect 0 -t 8000 -t 8080
forwards both ports 8000 and 8080 - Enables local access to remote web servers, APIs, and services
Copy Files
Transfer files between local and remote instance with the scp
command:
You can transfer files in either direction, from your local machine to an instance, or from the instance to your local machine. You indicate the direction of transfer with the path format, shown below.
Path format:
- Remote:
instance_id:path
(e.g.,0:/home/user/data
) - Local: Standard paths (e.g.,
./data
or/home/user/file.txt
) - Must specify exactly one remote and one local path
- Paths can be either absolute or relative.
Examples:
File transfers have a 60-second connection timeout. SSH key setup,
compression, and ~/
expansion are handled automatically.
System Management
Modify Instance
Modify the instance’s vCPU count, GPU type, or disk size:
All flags are optional, but at least one change must be provided.
These changes will affect the billing price of the instance.
Instances must be stopped to modify the vCPU count or GPU type. You can resize disk at any time.
Storage can only be increased, not decreased. For smaller storage needs, create a new instance and transfer your files.
View Instance Status
List all instances and details including instance_ID
, IP Address
, Disk Size
, GPU Type
, GPU Count
, vCPU Count
, RAM
, and Template
:
use the --no-wait
flag to disable automatic monitoring for status updates