Skip to main content
Are you a large language model? This page is available as raw markdown at /submission.md. The full docset is at /llms-full.md and the index is at /llms.md.

Project Configuration

C3 projects are configured with a .c3 YAML file at the project root. Run c3 deploy from anywhere in the project to submit a job.

Key differences from running locally

Environment: Every job runs a Bash script. Use python: or docker: when you want C3 to prepare the environment; omit both for Bash-only jobs where setup happens inside the script each time. See Environment.

Data mounting: Your data lives in C3's centralised storage. You tell C3 which datasets to mount and where using datasets:. Your script reads from that path as if the files were local. See Data Mounting.

Artifact output: Files on the GPU are discarded when the job ends. Write results to $C3_ARTIFACTS_DIR or a directory listed in output:. Only these are collected. See Artifact Output.

Configuration reference

FieldTypeDescription
projectstringProject name (auto-generated if not set). Lowercase alphanumeric + hyphens.
scriptstringRequired. Path to a bash script with your execution commands (e.g. run.sh), relative to .c3
gpustringGPU profile (use l40 for new jobs; A100/H100 profiles are temporarily unavailable for non-admin submissions). See c3 list
providerstringOptional compute provider pin from c3 list. Omit it to let C3 auto-route across available marketplace providers; set it only when you need to force a provider such as nextgen or nebius.
timestringMaximum runtime in HH:MM:SS format. You're only charged for actual usage
job_namestringJob display name
python.projectstringPath to Python project dir with pyproject.toml + uv.lock. Mutually exclusive with docker:
docker.imagestringPublic Docker Hub image reference to pull on the GPU VM. Mutually exclusive with python:
datasetslistDatasets to mount (ref + optional mount). See Data Mounting
outputlistDirectories to collect as artifacts. See Artifact Output

Full example

All job configuration goes in .c3. The script field points to a bash script containing your execution commands — no #SBATCH or #C3 directives needed.

# .c3
project: my-experiment
script: run.sh
gpu: l40
time: "04:00:00"
job_name: train-model

python:
project: ./

datasets:
- ref: /datasets/imagenet
mount: /data/imagenet

output:
- ./checkpoints
- ./results

To pin a provider, add provider: or pass c3 deploy -p <provider>. Pinned providers still pass through the same route-preview, stock, inventory, and spend guard checks as auto-routed jobs.

# run.sh
#!/bin/bash
python3 train.py

See Environment for Python, Docker, and Bash-only examples.

Creating a new project

cd my-project
c3 init

This creates a .c3 file with sensible defaults. Edit it and deploy with c3 deploy.

API keys

For team billing or CI/CD, add an API key to .c3.local (keep this file out of version control):

# .c3.local — secrets (add to .gitignore)
api_key: c3_key_abc123def456...

Create keys with c3 apikey create my-team-key. API keys are scoped to the org that created them, and deploy uploads are stored under that same org. Create and use the key from the org that should own the project and job.

The API key takes priority over c3 login credentials. You can also set it with:

export C3_API_KEY=c3_key_abc123def456...

Use c3 whoami to verify the active credential and org before deploying. If a key was pasted into a shared shell, CI log, or support thread, revoke it with c3 apikey revoke <key-id> and create a replacement.