9.5 KiB
Bambu-Run
Richer data, powerful customization for your Bambu Lab 3D printer.
Bambu-Run is a self-hosted web dashboard that gives you:
- Real-time monitoring and logging (temperatures, fan speeds, print progress, and more)
- Automatic filament inventory tracking and usage monitoring (AMS required)
All running on hardware you own.
What You'll Need
Any always-on device works — a Raspberry Pi (3B+, 4, or 5) is ideal: beginner-friendly, runs Raspberry Pi OS out of the box, and quiet enough to tuck behind a desk. An old PC or laptop with Linux works too.
It runs quietly in the background 24/7, capturing every print, filament change, and AMS update the moment it happens. And the power bill? A Raspberry Pi 4 under light load draws about 5W. That's roughly 43.8 kWh per year, or the cost of three cups of coffee. ☕☕☕ Tuck it out of sight and forget it's there.
Table of Contents
- Native Setup (Recommended for Raspberry Pi)
- Docker Setup
- Batch Importing Filament Colors and Filament Types
Native Setup (Recommended for Raspberry Pi)
No Docker required. Works on any Raspberry Pi (including 32-bit Pi Model B) running Raspberry Pi OS with Python 3.10+.
What You'll Need
- Raspberry Pi on your local network (Python 3.10+)
- Bambu Lab printer
- Bambu Lab account email and password
Clone and run setup.sh
git clone https://github.com/RunLit/Bambu-Run.git
cd Bambu-Run
bash setup.sh
That's it! The script handles everything interactively, just answer the prompts. When it finishes, open http://<ip> from any device on same network.
The script is safe to re-run at any time.
What the script does:
- Dependencies: creates a Python virtual environment, installs all packages
- Credentials: prompts for your BambuLab Cloud account email, password, and timezone; auto-generates a
DJANGO_SECRET_KEY; writes.env - Bambu Cloud auth: runs
bambu_collector --once;- Bambu Lab will send a 6-digit code to your email; check you email box and enter it when prompted;
- the resulting token is saved to
.envautomatically; future restarts skip this step
- Dashboard login: runs
createsuperuser; choose a username and password for Bambu-Run web UI log in - Services: installs and starts two systemd services (
bambu-run-webandbambu-run-collector), enables linger so they auto-start on boot - Port 80: sets an
iptablesredirect (80 to 8000) so you can reach the dashboard at a plainhttp://<pi-ip>with no port number; persisted viaiptables-persistentacross reboots.
Managing Bambu-Run
All commands manage Bambu-Run encapsulated in ./native/bambu-run.sh. Alternatively, you can do it yourself with systemctl commands.
./native/bambu-run.sh status # service status
./native/bambu-run.sh logs # tail live logs (Ctrl+C to stop)
./native/bambu-run.sh restart # restart both services
./native/bambu-run.sh stop # stop everything
./native/bambu-run.sh update # git pull + pip install + migrate + restart
Troubleshooting (Native)
Services die when SSH disconnects: sudo loginctl enable-linger $USER
Services not starting: ./native/bambu-run.sh status and ./native/bambu-run.sh logs
Auth errors / token expired: Remove BAMBU_TOKEN from .env and re-run bash setup.sh
Uninstall:
systemctl --user disable --now bambu-run-web bambu-run-collector
rm ~/.config/systemd/user/bambu-run-{web,collector}.service
systemctl --user daemon-reload
Wipe everything and start over:
# Stop and remove services
systemctl --user stop bambu-run-web bambu-run-collector
systemctl --user disable bambu-run-web bambu-run-collector
rm ~/.config/systemd/user/bambu-run-{web,collector}.service
systemctl --user daemon-reload
# Remove port 80 redirect (if it was set)
sudo iptables -t nat -D PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8000 2>/dev/null || true
sudo iptables -t nat -D OUTPUT -o lo -p tcp --dport 80 -j REDIRECT --to-port 8000 2>/dev/null || true
sudo netfilter-persistent save 2>/dev/null || true
# Delete repo — wipes venv, database, and .env
cd ~
rm -rf ~/Bambu-Run
# Re-clone and run setup from scratch
git clone https://github.com/RunLit/Bambu-Run.git
cd Bambu-Run
bash setup.sh
Docker Setup
Requires Docker and Docker Compose installed. Assumes you already know how to get there.
Clone and configure:
git clone https://github.com/RunLit/Bambu-Run.git
cd Bambu-Run
cp .env.example .env
# Edit .env: set BAMBU_USERNAME, BAMBU_PASSWORD, TIMEZONE
First-time auth (Bambu Lab sends a 6-digit verification code to your email):
docker compose build
docker compose run --rm bambu-run python standalone/manage.py migrate --noinput
docker compose run --rm bambu-run python standalone/manage.py bambu_collector --once
# Paste the printed token into .env as BAMBU_TOKEN=...
Start and create your dashboard login:
docker compose up -d
docker compose exec bambu-run python standalone/manage.py createsuperuser
Dashboard is at http://<host-ip>:8000.
Common operations:
docker compose logs -f # live logs
docker compose down # stop (data preserved in volume)
git pull && docker compose up -d --build # update
Troubleshooting: Auth errors → remove BAMBU_TOKEN from .env and re-run the auth step. No data → check docker compose logs -f for MQTT connection errors.
Batch Importing Filament Colors and Filament Types
Bambu-Run ships with a full Bambu Lab color catalog under docs/Bambu_Color_Catalog/ (one .txt file per filament sub-type, e.g. PLA Basic.txt, PETG HF.txt). Importing these populates the Filament Colors database so the dashboard shows proper color names instead of raw hex codes.
Adding your own colors
Need a filament type that isn't in the bundled catalog? Create your own .txt file and point the importer at it.
File naming — the filename determines the filament type and sub-type:
PLA Basic.txt → type: PLA, sub-type: PLA Basic
PETG HF.txt → type: PETG, sub-type: PETG HF
ABS.txt → type: ABS, sub-type: ABS
File format — list each color on its own line, either as two rows (name then hex) or on the same line:
Jade White
Hex:#FFFFFF
Black Walnut #4F3F24
Bambu Lab's website filament pages and their downloadable PDF catalogs are a reliable source — both list color names alongside hex codes you can copy directly.
When to run this
Run the import once after first setup to seed the full color catalog in one go, rather than adding colors one by one. Run it again any time you want to add colors for a new filament type. Re-running is always safe — duplicates are detected and skipped automatically.
Import all colors (recommended)
If the container is already running (docker compose up -d):
docker compose exec bambu-run python standalone/manage.py bambu_import_colors docs/Bambu_Color_Catalog/
If the container is not running yet:
docker compose run --rm bambu-run python standalone/manage.py bambu_import_colors docs/Bambu_Color_Catalog/
Import a file from your computer
If your .txt color file lives on your Mac, Pi, or any machine running Docker (i.e. not inside the repo), copy it into the container first, then run the importer:
# Step 1 — copy the file from your machine into the container
docker compose cp /path/to/your/PLA\ Basic.txt bambu-run:/tmp/
# Step 2 — run the importer against the copied path
docker compose exec bambu-run python standalone/manage.py bambu_import_colors /tmp/PLA\ Basic.txt
To import a whole folder of files at once:
# Step 1 — copy the folder
docker compose cp /path/to/your/color_catalog/ bambu-run:/tmp/color_catalog/
# Step 2 — import everything in it
docker compose exec bambu-run python standalone/manage.py bambu_import_colors /tmp/color_catalog/
macOS tip: You can drag a file from Finder into the terminal to paste its full path.
Import a single filament type
To import only one sub-type from the bundled catalog (e.g. just PLA Basic):
docker compose exec bambu-run python standalone/manage.py bambu_import_colors "docs/Bambu_Color_Catalog/PLA Basic.txt"
Preview before importing (dry run)
Check what would be added without writing anything to the database:
docker compose exec bambu-run python standalone/manage.py bambu_import_colors docs/Bambu_Color_Catalog/ --dry-run
What the output means
Processing: PLA Basic.txt → type='PLA' sub_type='PLA Basic'
Parsed 40 color(s).
+ 'Bambu Green' #009F87 (PLA / PLA Basic)
+ 'Jade White' #FFFFFF (PLA / PLA Basic)
...
──────────────────────────────────────────────────
Created: 40
Skipped (duplicate): 0
- Created — new color entries added to the database
- Skipped (duplicate) — already existed, not changed
- Skipped (no type) — only shown if
--no-auto-create-filament-typeis used and the filament type isn't in the database yet
