CLI for interacting with Colab.
Project description
Colab CLI
A command-line interface for Google Colab. Provision high-performance CPU, GPU, and TPU runtimes, execute local code, manage remote files, and orchestrate automated cloud pipelines — directly from your terminal.
Designed to support seamless developer productivity, headless automation, and AI agent integrations.
Key Features
- Instant VM Provisioning: Spin up CPU, GPU (T4, L4, G4, H100, A100), or TPU (v5e1, v6e1) runtimes in seconds.
- Robust Code Execution: Run local Python scripts, Jupyter Notebooks (
.ipynb), or pipedstdincode; launch interactive REPLs or raw TTY console shells. - Ephemeral Job Runner (
colab run): Provision a fresh VM, execute a local script with forwarded arguments, retrieve output files, and automatically tear down the runtime in a single command. - Automatic Keep-Alive: Built-in background daemon automatically prevents idle VM termination, keeping resource allocations active without requiring open browser tabs.
- Seamless Workspace Automation: Mount Google Drive, authenticate Google Cloud Platform (GCP) credentials, and install dependencies with high-performance
uvpackage management. - State & Log Archival: Inspect local session states or export interactive history logs to standard Jupyter Notebooks, Markdown, or structured JSONL.
Installation
Install the package using uv (recommended) or standard pip:
# Using uv (recommended)
uv tool install google-colab-cli
# Using pip
pip install google-colab-cli
Quick Start
Run a CPU-based VM runtime, execute some code, and clean up:
# 1. Provision a new session
colab new
# 2. Execute code from stdin
echo "print('Hello from Google Colab!')" | colab exec
# 3. Stop and release the VM resource
colab stop
[!NOTE] When only one session is active, you can omit the
-s, --sessionoption; the CLI automatically knows it.
Command Index
Run colab <command> --help to view specific options, defaults, and detailed help.
Session Management
| Command | Description |
|---|---|
colab new [-s NAME] [--gpu GPU] [--tpu TPU] |
Allocate a new CPU, GPU, or TPU VM runtime |
colab sessions |
List all active sessions currently active on the backend |
colab status [-s NAME] |
Display hardware, status, and local metadata for active sessions |
colab restart-kernel [-s NAME] |
Restart the active session's Jupyter kernel |
colab stop [-s NAME] |
Terminate a session VM and tear down its keep-alive daemon |
colab url [-s NAME] [--open] |
Print or open a browser URL connecting to the active session |
Execution
| Command | Description |
|---|---|
colab run [--gpu GPU] [--tpu TPU] [--keep] SCRIPT [ARGS...] |
Run a local script on a fresh VM, forwarding arguments, then release it |
colab exec [-s NAME] [-f FILE] [--output-image PATH] |
Execute Python code from stdin, a local .py file, or a .ipynb notebook |
colab repl [-s NAME] [--output-image PATH] |
Start an interactive Python REPL on the VM (exits cleanly on piped EOF) |
colab console [-s NAME] |
Connect to a raw interactive TTY shell (tmux) on the remote VM |
File Operations
| Command | Description |
|---|---|
colab ls [-s NAME] [PATH] |
List remote files on the VM |
colab upload [-s NAME] LOCAL REMOTE |
Upload a local file to the VM filesystem |
colab download [-s NAME] REMOTE LOCAL |
Download a remote file from the VM filesystem |
colab rm [-s NAME] PATH |
Delete a remote file on the VM filesystem |
colab edit [-s NAME] PATH |
Edit a remote file in-place using your local $EDITOR |
Automation & Utilities
| Command | Description |
|---|---|
colab auth [-s NAME] |
Authenticate the VM for GCP services (BigQuery, GCS, etc.) |
colab drivemount [-s NAME] [PATH] |
Mount Google Drive on the VM (default: /content/drive) |
colab install [-s NAME] [-r FILE | PKG...] |
Install packages on the VM using uv (falls back to pip) |
colab log [-s NAME] [-n N] [-o FILE] |
View or export session history (.ipynb, .md, .txt, .jsonl) |
colab pay |
Open the Colab subscription page to manage compute units |
colab version |
Print the installed version of the CLI |
colab update [--install] |
Check for a newer release (and optionally upgrade the CLI in place) |
Global Options
--auth {oauth2,adc}— Authentication strategy for the Colab API (default:adc).-c, --client-oauth-config PATH— Path to public OAuth client credentials configuration (default:~/.colab-cli-oauth-config.json).--config PATH— Path to local session metadata storage (default:~/.config/colab-cli/sessions.json).--logtostderr— Direct debug logging output to stderr.
Practical Examples
Accelerator Training with Checkpoint Retrieval
Provision an A100 GPU, install requirements, run a local training script, retrieve the resulting model weights, and terminate the VM:
colab new -s trainer --gpu A100
colab install -s trainer torch transformers
colab exec -s trainer -f train.py
colab download -s trainer checkpoints/model.bin ./model.bin
colab stop -s trainer
Workspace Notebook Execution with Drive Integration
Mount Google Drive, run a local notebook against the VM kernel (outputs are written back into report_output.ipynb), export a Markdown log of the execution, and clean up:
colab new -s analysis
colab drivemount -s analysis
colab exec -s analysis -f report.ipynb
colab log -s analysis -o execution_log.md
colab stop -s analysis
Usage Notes
- TTY Requirements: The interactive commands
replandconsolerequire a local TTY. When running inside automated scripts or pipelines, make sure to pipe stdin (e.g.,echo "print(1)" | colab repl) to trigger non-interactive execution modes. - Transparent Code Execution: When calling
colab exec -f file.py, the CLI reads the file locally and transmits its content to the remote kernel. You do not need to manually upload files before execution. - Storage & State Paths: Session tokens and metadata are stored at
~/.config/colab-cli/sessions.json. Global CLI settings are located at~/.config/colab-cli/settings.json. These can be customized or isolated via the global--configflag.
Ephemeral Accelerator Jobs
Use colab run to run a local script on dedicated hardware without manual session lifecycle management. The CLI handles provisioning, script execution, and immediate VM teardown automatically:
# Run train.py on a T4 GPU and release the VM on completion
colab run --gpu T4 train.py
Shebang Execution Support
To execute a local file directly on a remote accelerator, place the colab run interpreter in the shebang line:
#!/usr/bin/env -S colab run --gpu L4 --keep
import torch
print("L4 GPU Available:", torch.cuda.is_available())
print("Device Name:", torch.cuda.get_device_name(0))
Make the script executable (chmod +x script.py) and run it: ./script.py. The --keep option tells the CLI to preserve the session VM on completion so you can re-execute or inspect logs.
Deep Dive Documentation
For comprehensive architectural overviews and deep-dives into specific CLI sub-systems, refer to the detailed documentation:
- Session Management & Keep-Alive Architecture
- Interactive & Non-Interactive Execution Design
- File Management & Jupyter Contents API
- Authentication Providers & VM Automation
- Ephemeral Job Runner Design
To view interactive walkthroughs of eleven real-world automated scenarios, check out the Demo Walkthroughs.
Contributing
Feedback and contributions are welcome! Please read CONTRIBUTING.md for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file google_colab_cli-0.5.9.tar.gz.
File metadata
- Download URL: google_colab_cli-0.5.9.tar.gz
- Upload date:
- Size: 200.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f37bb06e8e2449e91c64a08a9be691c138fd7d4f95f706706766b95b004825b0
|
|
| MD5 |
fe514d053637fc927fe0332efaa0843f
|
|
| BLAKE2b-256 |
829ebc1bcdb1265f739cd5812e4e91a59f750378e58f4f2061e555d8601f525d
|
Provenance
The following attestation bundles were made for google_colab_cli-0.5.9.tar.gz:
Publisher:
google-colab-cli-py@oss-exit-gate-prod.iam.gserviceaccount.com
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
google_colab_cli-0.5.9.tar.gz -
Subject digest:
f37bb06e8e2449e91c64a08a9be691c138fd7d4f95f706706766b95b004825b0 - Sigstore transparency entry: 1715187737
- Sigstore integration time:
-
Token Issuer:
https://accounts.google.com -
Service Account:
google-colab-cli-py@oss-exit-gate-prod.iam.gserviceaccount.com
-
Statement type:
File details
Details for the file google_colab_cli-0.5.9-py3-none-any.whl.
File metadata
- Download URL: google_colab_cli-0.5.9-py3-none-any.whl
- Upload date:
- Size: 69.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.11.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f62fcb50889bd1089491624a65f376f4591e806fcea05133b4fc3ff96e85392b
|
|
| MD5 |
f702d3765073b11b39ba81df24c41235
|
|
| BLAKE2b-256 |
a3c6d561dce2c5b98ac343bc35f44a0b9a95208fb530d81e60bf3450785f5937
|
Provenance
The following attestation bundles were made for google_colab_cli-0.5.9-py3-none-any.whl:
Publisher:
google-colab-cli-py@oss-exit-gate-prod.iam.gserviceaccount.com
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
google_colab_cli-0.5.9-py3-none-any.whl -
Subject digest:
f62fcb50889bd1089491624a65f376f4591e806fcea05133b4fc3ff96e85392b - Sigstore transparency entry: 1715187667
- Sigstore integration time:
-
Token Issuer:
https://accounts.google.com -
Service Account:
google-colab-cli-py@oss-exit-gate-prod.iam.gserviceaccount.com
-
Statement type: