FastAPI backend & desktop launcher for running local models via llama.cpp
Project description
๐ฆ LLamaStudio
A desktop chat interface and local server manager for llama.cpp, crafted with FastAPI + HTMX for ultra-lightweight, zero-framework execution.
LLamaStudio is a self-contained local workspace that manages model lifecycles, features a smart VRAM estimator, scans local folders, and lets you search and download models directly from the Hugging Face Hub.
๐ธ Screenshots & Showcase
1. Main Chat Dashboard
A Pop!_OS-harmonized dark interface with streaming, collapsible markdown reasoning (thinking) processes, and real-time agentic tool execution logs.
2. GGUF Model Browser & Settings
A dynamic local model explorer that scans your directories and lets you adjust context length, GPU offload layers, CPU threads, flash attention, and KV cache quantizations on the fly.
3. Hugging Face Discover Hub
Browse the entire Hugging Face GGUF catalog. Features a Smart VRAM Offload Estimator calibrated to your hardware, and a floating background download progress card with live speed (MB/s), ETA, and cancel controls.
โจ Key Features
- โก Zero Node Modules: Built with HTMX, Tailwind CSS (via CDN), and Vanilla JS. It is incredibly fast, responsive, and has a memory footprint of just a few megabytes.
- ๐งญ Hugging Face Discover Tab: Search the public Hugging Face Hub for GGUF models directly inside the app, view readmes, select quantizations, and download files in the background.
- ๐ Smart VRAM Estimator: calulated specifically for your hardware (fits fully on RTX 5090 32GB VRAM, partial offload warning, or heavy CPU fallback warning).
- ๐ Automatic Model Scanning: Scans standard directories (like
~/.lmstudio/models) automatically on startup or via a one-click rescan button. - ๐ช Process Lifecycle Manager: The underlying
llama-serverprocess only spins up when you explicitly load a model, releasing all system resources and GPU VRAM instantly when you click "Eject". - ๐ง Configurable Workspace Sandboxing: Supports sandboxed agentic tool use (file read/write, commands, etc.) with real-time logs in the UI. Workspace and permission defaults are stored in the first-class app config.
- ๐ฅ๏ธ XDG-Compliant Persistence: App config, conversations, and first-class model profiles are stored outside the codebase directory in standard
~/.config/llamastudio/with automated backward-compatible migrations. - ๐ฆ Full Linux & macOS Portability: Server binaries and model directories are resolved dynamically on startup.
๐ ๏ธ Installation & Setup
LLamaStudio is compatible with Linux and macOS out-of-the-box. Choose your OS and python virtual environment preference below.
๐ง 1. Linux Installation
Prerequisites
- Python 3.10+ (Recommended: Python 3.13)
- llama.cpp built from source (or pre-compiled binary):
- By default, the app dynamically looks for the
llama-serverbinary globally on your system PATH or locally inside your home directory at~/llama.cpp/build/bin/llama-server.
- By default, the app dynamically looks for the
Environment Setup
Option A: Install from PyPI
pip install llamastudio
Option B: Conda / Miniconda from source
# 1. Clone the repository
git clone https://github.com/gnulnx/LlamaStudio.git
cd LlamaStudio
# 2. Create and activate a conda environment
conda create -n llamastudio python=3.13 -y
conda activate llamastudio
# 3. Install LlamaStudio and its dependencies
pip install -e .
Option C: Python Virtualenv (venv) from source
# 1. Clone the repository
git clone https://github.com/gnulnx/LlamaStudio.git
cd LlamaStudio
# 2. Create and activate a python venv environment
python3 -m venv .venv
source .venv/bin/activate
# 3. Install LlamaStudio and its dependencies
pip install -e .
๐ฅ๏ธ Linux Desktop Launcher Integration (Optional)
To integrate LLamaStudio directly into your Linux Application launcher menu (e.g., GNOME / Pop!_OS):
# 1. Copy the desktop file to your local applications directory
cp llamastudio.desktop ~/.local/share/applications/
# 2. Copy the custom SVG icon to your local icons directory
mkdir -p ~/.local/share/icons/hicolor/128x128/apps/
cp llamastudio.svg ~/.local/share/icons/hicolor/128x128/apps/
# 3. Update your desktop database and icon cache
update-desktop-database ~/.local/share/applications/
gtk-update-icon-cache -f -t ~/.local/share/icons
Note: If you are using a virtualenv, edit the executable path inside ~/.local/share/applications/llamastudio.desktop to point to your specific .venv/bin/python interpreter.
๐ 2. macOS Installation
Prerequisites
- Python 3.10+
- llama.cpp installed globally via Homebrew (highly recommended for macOS):
brew install llama.cpp
(This automatically places thellama-serverbinary globally on your system PATH, which LLamaStudio will auto-detect immediately!)
Environment Setup
Option A: Install from PyPI
pip install llamastudio
Option B: Conda / Miniconda from source
# 1. Clone the repository
git clone https://github.com/gnulnx/LlamaStudio.git
cd LlamaStudio
# 2. Create and activate environment
conda create -n llamastudio python=3.13 -y
conda activate llamastudio
# 3. Install LlamaStudio and its dependencies
pip install -e .
Option C: Python Virtualenv (venv) from source
# 1. Clone the repository
git clone https://github.com/gnulnx/LlamaStudio.git
cd LlamaStudio
# 2. Create and activate venv
python3 -m venv .venv
source .venv/bin/activate
# 3. Install LlamaStudio and its dependencies
pip install -e .
๐ช 3. Windows Installation
Note: Native Windows execution is currently untested. However, you can run LLamaStudio on Windows seamlessly via WSL2 (Windows Subsystem for Linux) by following the standard Linux Installation guide above.
Pull requests extending native Windows support (e.g., resolving .exe binaries) are highly welcome!
๐ Running the Application
Option A: Via Unified CLI (lls - Recommended)
You can link and install LlamaStudio's CLI utility locally to control the desktop app and server seamlessly:
# Start the desktop application server and open browser UI
lls start
Option B: Via App Launcher Command
After installing from PyPI or source, run:
llamastudio
Via Application Menu (Linux)
Search for LLamaStudio in your desktop search bar (press Super, type "Llama") and click to launch!
๐ ๏ธ Unified Command-Line Interface (lls)
LlamaStudio features a CLI built using rich-click for visual dashboards and operational efficiency.
CLI Subcommands Reference
| Command | Usage | Description |
|---|---|---|
start |
lls start |
Starts the desktop app and opens the browser to the right first-run/chat/models/discover view. |
reload |
lls reload |
Gracefully restarts the desktop FastAPI application backend. |
status |
lls status |
Visual dashboard of FastAPI backend status, loaded model parameters, and GPU memory (VRAM). |
ls |
lls ls |
Prints an elegant table of all GGUF models scanned across local directories. |
load |
lls load [MODEL] |
Boots the server with a GGUF model. If MODEL is omitted, prompts you with an interactive menu. |
eject |
lls eject |
Gracefully unloads the active model to free GPU and CPU RAM. |
oneshot |
lls oneshot "prompt" |
Streams thinking traces, text, and executes agentic tools directly in your terminal. |
For example, to boot a model interactively:
$ lls load
Available Scanned Models:
1. Qwen3.6-35B-A3B-UD-Q5_K_M (25.2 GB)
2. gemma-4-26B-A4B-it-Q8_0 (25.0 GB)
3. DeepSeek-R1-Distill-Qwen-32B-Q5_K_M (21.7 GB)
Select a model number to load: 3
Loading model 'DeepSeek-R1-Distill-Qwen-32B-Q5_K_M'...
โ๏ธ Configuration & Customization
The application runs fully out-of-the-box with no manual configuration. On first launch, LlamaStudio creates its runtime config under:
~/.config/llamastudio/
config.json
model_profiles.json
conversations.json
logs/
config.json stores app defaults, model search directories, workspace permissions, and launch state. model_profiles.json stores first-class per-model load and inference profiles. Older model_settings.json files are migrated automatically.
๐ก๏ธ Workspace Sandboxing & Embodiment
By default, LlamaStudio restricts agent tools (like reading, writing, and listing files) to the configured workspace directory to prevent accidental path traversals. For CLI launches, the first-run workspace defaults to the directory where lls start was run.
Workspace configuration is saved in ~/.config/llamastudio/config.json. Environment variables are still supported for advanced/bootstrap overrides, but normal users should not need a .env file.
Developer details for the config/profile architecture live in DEV.md.
๐งช Testing Suite
LlamaStudio features both standard unit tests and comprehensive GGUF integration tests.
1. Standard Unit Tests
Verify local installation and confirm backend routing, regex parsing, and sandboxing safety behaviors by running our mock-based test suite:
python -m unittest discover tests
2. GGUF Model Integration Tests
For local environments containing active GPUs and downloaded models, you can run the full multi-model GGUF tool-calling integration suite to verify real-time execution robustness across various chat templates:
# Run GGUF model integration tests locally
./tests/test_all.sh
(These tests are automatically skipped in standard CI/CD environments and default pytest runs using @pytest.mark.skipif to keep pipeline checks fast.)
๐๏ธ Project Structure
LlamaStudio/
โโโ pyproject.toml # Package metadata, CLI entrypoint, and dependencies
โโโ DEV.md # Development notes for runtime config and profiles
โโโ llamastudio.desktop # GNOME/Linux desktop launcher metadata
โโโ llamastudio.svg # Custom application vector icon
โโโ app/
โ โโโ config.py # Settings & dynamic path configurations
โ โโโ config_store.py # First-class runtime config and model profiles
โ โโโ main.py # FastAPI backend endpoints & routing
โ โโโ chat.py # Conversations registry, templates & chat streaming
โ โโโ downloader.py # Async background download manager (chunked writes)
โ โโโ model_manager.py # Scans local paths and Hugging Face Hub
โ โโโ server_manager.py # llama-server subprocess process lifecycle controller
โ โโโ logger.py # Centralized logger
โ โโโ tools.py # Sandboxed local workspace tools for LLM agent use
โ โโโ templates/
โ โโโ index.html # Interactive HTMX frontend interface
โโโ tests/
โ โโโ *.py # Unit and integration-adjacent test coverage
โโโ imgs/
โโโ chat_interface.png # Screenshot: Main Chat interface
โโโ model_settings.png # Screenshot: Model explorer & settings
โโโ discover_models.png# Screenshot: HF Discover & Downloader panel
๐ License
LLamaStudio is open-source software licensed under the MIT License.
Project details
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 llamastudio-1.0.5.tar.gz.
File metadata
- Download URL: llamastudio-1.0.5.tar.gz
- Upload date:
- Size: 230.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
95d95fd89b4c9d17ae75c19f8bb52b067741c467cf98542d0ecbb35d8b5d2052
|
|
| MD5 |
9fa5fa4b78a33f0ac0e5e336a14ec1da
|
|
| BLAKE2b-256 |
4db2b1ed3446da38b6701e3ec81f6ca79fa07140383de9e5c8e3bf857a868284
|
File details
Details for the file llamastudio-1.0.5-py3-none-any.whl.
File metadata
- Download URL: llamastudio-1.0.5-py3-none-any.whl
- Upload date:
- Size: 217.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b6c22d6fade2a062374e564d4ae3b51d26e99b58c3ddf1611c2d6a05520897b6
|
|
| MD5 |
33528e80f3f707a8124d74f2f7e0d229
|
|
| BLAKE2b-256 |
44a12238c8e759d4971d36314265bad1cac44fca182d36e1550c6f675980701a
|