jupyter/skills/jupyter-ml-notebook/SKILL.md
Full CUDA ML JupyterLab box with finetuning, Ollama, and LLM course notebooks, CRDT MCP server, and real-time collaboration. Base: nvidia. Port 8888. Combines jupyter-ml with 37 Unsloth fine-tuning notebooks, 6 Ollama integration notebooks, and 15 LLM course notebooks. MUST be invoked before building, deploying, or troubleshooting the jupyter-ml-notebook box.
npx skillsauth add overthinkos/overthink-plugins jupyter-ml-notebookInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
jupyter-ml-notebook:
base: nvidia
candy:
- agent-forwarding
- jupyter-ml
- notebook-templates
- notebook-finetuning
- notebook-ollama
- notebook-llm-on-supercomputers
- notebook-openrouter
- dbus
- charly
ports:
- "8888:8888"
platforms:
- linux/amd64
This box is identical to jupyter-ml with two data candy additions:
notebook-finetuning — seeds 37 Unsloth fine-tuning notebooks into /workspace/finetuning/notebook-ollama — seeds 6 Ollama integration notebooks into /workspace/ollama/The Ollama notebooks require a running ollama deployment. When deployed via charly config ollama --update-all, the OLLAMA_HOST env var is automatically injected via env_provide -- no manual configuration needed.
jupyter-ml — Tier 2 environment-owning meta-layer (PyTorch >= 2.10.0, vLLM 0.19, unsloth, LangChain, CRDT MCP via jupyter-mcp sub-candy)notebook-templates — Starter notebooks (data candy, seeds /workspace)notebook-finetuning — 37 Unsloth fine-tuning notebooks (data candy, seeds /workspace/finetuning/)notebook-ollama — 6 Ollama integration notebooks (data candy, seeds /workspace/ollama/)notebook-llm-on-supercomputers — 15 LLM course notebooks (data candy, seeds /workspace/llms_on_supercomputers/)agent-forwarding — SSH/GPG agent forwardingdbus — D-Bus session buscharly — OpenCharly CLI| Port | Service |
|------|---------|
| 8888 | JupyterLab + MCP endpoint at /mcp |
| Name | Path | Purpose | |------|------|---------| | workspace | /workspace | Persistent notebook storage | | models | ~/.cache/huggingface | HuggingFace model cache (from unsloth sub-candy) |
| Candy | Target | Dest | Contents | |-------|--------|------|----------| | notebook-templates | workspace | (root) | getting-started.ipynb | | notebook-finetuning | workspace | finetuning/ | 37 Unsloth notebooks (SFT, GRPO, DPO, RLOO, QLoRA) | | notebook-ollama | workspace | ollama/ | 6 Ollama API notebooks (requests, OpenAI, ollama lib, GPU, HuggingFace, Anthropic) | | notebook-llm-on-supercomputers | workspace | llms_on_supercomputers/ | 15 LLM course notebooks (prompt engineering, RAG, fine-tuning) + datasets |
/workspace/
getting-started.ipynb (from notebook-templates)
finetuning/ (from notebook-finetuning)
.env.example
notebooks.yaml
00_Unsloth_Setup.ipynb
01_FastInference_Llama.ipynb
01_FastInference_Qwen.ipynb
02_Vision_Training_Ministral.ipynb
03_SFT_Training_Qwen.ipynb
04_GRPO_Training_Qwen.ipynb
05_DPO_Training_Qwen.ipynb
06_Reward_Training_Qwen.ipynb
07_RLOO_Training_Qwen.ipynb
08_QLoRA_Alpha_Scaling_Ministral.ipynb
... (37 notebooks total)
ollama/ (from notebook-ollama)
notebooks.yaml
00_Ollama_Requests.ipynb
01_Ollama_GPU.ipynb
02_Ollama_OpenAI.ipynb
03_Ollama_Library.ipynb
04_Ollama_HuggingFace.ipynb
05_Ollama_Anthropic.ipynb
llms_on_supercomputers/ (from notebook-llm-on-supercomputers)
notebooks.yaml
datasets/
D0_00_Bazzite_Setup.ipynb
D1_01_Prompting_with_LangChain.ipynb
D1_02_Prompt_templates_and_parsing.ipynb
... (15 notebooks total)
This box is a consumer of env_provide variables from infrastructure candies:
| Variable | Injected by | Value |
|----------|------------|-------|
| OLLAMA_HOST | /charly-ollama:ollama | http://charly-ollama:11434 |
The notebooks read OLLAMA_HOST via os.getenv("OLLAMA_HOST", "http://localhost:11434"). When ollama is deployed via charly config ollama --update-all, the env_provide mechanism overrides the localhost default automatically.
charly box build jupyter-ml-notebook
charly config jupyter-ml-notebook
charly start jupyter-ml-notebook
charly status jupyter-ml-notebook
charly logs jupyter-ml-notebook -f
# JupyterLab: http://localhost:8888
# MCP endpoint: http://localhost:8888/mcp
# With bind-backed workspace (data seeded into local dir):
charly config jupyter-ml-notebook --bind workspace=/path/to/project
The notebook-finetuning include compatibility fixes for current library versions:
charly shell jupyter-ml-notebook -c "pixi run verify-pytorch"
charly shell jupyter-ml-notebook -c "pixi run verify-unsloth"
charly shell jupyter-ml-notebook -c "pixi run verify-mcp"
charly shell jupyter-ml-notebook -c "ls /workspace/finetuning/"
charly shell jupyter-ml-notebook -c "ls /workspace/ollama/"
charly shell jupyter-ml-notebook -c "ls /workspace/llms_on_supercomputers/"
/charly-jupyter:jupyter-ml — Same stack without finetuning notebooks/charly-jupyter:jupyter — Lightweight variant (no CUDA, multi-arch)/charly-jupyter:unsloth-studio — Unsloth Studio UI (different pixi env, same finetuning notebooks)MCP testing: same 3 deploy-scope mcp: checks as jupyter-ml are inherited here. See /charly-build:charly-mcp-cmd for the verb reference.
MUST be invoked before building, deploying, configuring, or troubleshooting the jupyter-ml-notebook box.
/charly-image:image — image family umbrella (box: entries in charly.yml, build/validate/inspect/list)/charly-build:build — build.yml vocabulary (distros, builders, init-systems)tools
OpenCharly CLI (charly) binary installed into container/VM images for in-container use. Use when working with charly binary deployment inside containers, native D-Bus support, or the full charly toolchain (charly binary + virtualization + gocryptfs + socat).
development
Operator CachyOS workstation profile — a kind:local template + target:local deploy that installs the full dev stack (30 candies) onto a CachyOS host via ShellExecutor. Lives in the overthinkos/cachyos submodule. MUST be invoked before editing or applying the charly-cachyos workstation profile.
tools
Fedora box with the full charly toolchain using shared candies. Rootless-first — runs as uid=1000 with passwordless sudo (no root, no cap_add: ALL). Same candy list as charly-arch. Includes NVIDIA GPU runtime. MUST be invoked before building, deploying, configuring, or troubleshooting the charly-fedora box.
tools
Arch Linux box with the full charly toolchain. Rootless-first — runs as uid=1000 with passwordless sudo (no root, no cap_add: ALL). Composes /charly-coder:charly-mcp so the box is reachable as an MCP gateway on port 18765. NVIDIA GPU runtime composed in. MUST be invoked before building, deploying, configuring, or troubleshooting the charly-arch box.