AI News HubLIVE
In-site rewrite6 min read

Show HN: A durable filesystem layer for AI agents

SmolFS provides AI agents with persistent workspace folders that survive process restarts, supporting local dev (SQLite) and cloud volumes (Redis + S3) with a unified CLI and Python/TypeScript SDKs.

SourceHacker News AIAuthor: theaniketmaurya

Uh oh!

There was an error while loading. Please reload this page.

Notifications You must be signed in to change notification settings

Fork 0

Star 4

BranchesTags

Open more actions menu

Folders and files

NameName

Last commit message

Last commit date

Latest commit

History

13 Commits

13 Commits

.github/workflows

.github/workflows

bindings

bindings

crates

crates

scripts

scripts

.gitignore

.gitignore

AGENTS.md

AGENTS.md

Cargo.lock

Cargo.lock

Cargo.toml

Cargo.toml

README.md

README.md

Repository files navigation

Durable workspace folders for AI agents.

Quickstart | Lifecycle | Python SDK | TypeScript SDK | Development | Releases

SmolFS gives agents a workspace folder that can survive after the agent process stops. You mount it like a normal directory, write files into it, unmount it when the job is done, and mount it again later from another process.

SmolFS owns the developer experience around creating volumes, checking the machine, mounting, flushing, unmounting, and inspecting status. The storage backend is installed and managed for you.

Durable workspaces

Agents can keep files across short-lived runtimes without each runtime managing storage setup directly.

Read more ->

Local dev mode

Use --dev for a local-only volume backed by SQLite metadata and local object files.

Read more ->

Cloud volumes

Use Redis plus S3-compatible object storage when the same workspace needs to outlive one machine.

Read more ->

One CLI lifecycle

Run doctor, init, mount, flush, status, and unmount from one command.

Read more ->

Thin SDKs

Python and TypeScript bindings call the same Rust core so agent tools can use SmolFS without shelling out.

Read more ->

Explicit configuration

Cloud metadata, buckets, and credentials stay explicit so durable agent data is easier to audit.

Read more ->

Use Cases

Keep agent work across turns. Mount the same workspace again after an agent process exits.

Share a workspace across runtimes. Put metadata in Redis and file contents in S3-compatible storage.

Test locally before using cloud storage. Start with --dev, then switch to explicit metadata and object storage settings.

Wrap storage in agent tooling. Use the Python or TypeScript SDK from an agent runner instead of teaching every agent process about storage internals.

Quickstart

Install SmolFS:

curl -fsSL https://raw.githubusercontent.com/CelestoAI/smolfs/main/scripts/install.sh | sh

The installer downloads the latest CLI release asset for your platform and installs SmolFS' managed storage backend. If no release asset exists yet, use the source checkout flow in Development. Set SMOLFS_INSTALL_BACKEND=0 if you only want to install the CLI. Set SMOLFS_VERSION=dev to try the latest successful build from main; tagged v* releases remain the stable channel.

Check the machine and try a local volume:

smolfs doctor smolfs init demo --dev smolfs mount demo ./workspace echo hello > ./workspace/hello.txt smolfs flush demo smolfs unmount demo smolfs mount demo ./workspace cat ./workspace/hello.txt

SmolFS needs local mount support on the machine that mounts volumes. Mount support lets SmolFS provide a folder your tools can read and write.

Install the Python SDK with the CLI

curl -fsSL https://raw.githubusercontent.com/CelestoAI/smolfs/main/scripts/install.sh | SMOLFS_INSTALL_PYTHON=1 sh

The installer runs uv add smolfs from a directory with pyproject.toml, or uv pip install smolfs inside an active virtualenv. Set SMOLFS_PYTHON_MODE=user to use uv pip install --user smolfs.

CLI Lifecycle

The normal SmolFS flow is: check the machine, create a volume, mount it, use the directory, flush important writes, unmount it, and mount it again when you need the same files later.

Check the Machine

Run doctor before creating or mounting volumes:

smolfs doctor

doctor checks whether SmolFS has its managed storage backend and whether the machine can mount local directories.

Useful options:

smolfs doctor --install installs SmolFS' managed storage backend.

smolfs doctor --json prints the same report as JSON for scripts.

SmolFS looks for its home directory in SMOLFS_HOME. If it is not set, SmolFS uses ~/.smolfs. The home directory stores SmolFS config, volume records, logs, managed binaries, and local dev-volume data.

Create a Local Volume

A volume is the named workspace that SmolFS can mount later.

smolfs init demo --dev

--dev creates a local-only volume. It uses SQLite for metadata and local files for object data under the SmolFS home directory. This is the simplest path for trying SmolFS on one machine.

Create a Cloud Volume

Cloud volumes need explicit metadata and object storage settings. Metadata stores the file tree. Object storage is where file contents live.

smolfs init agent-workspace \ --metadata redis://localhost:6379/1 \ --storage s3 \ --bucket https://my-bucket.s3.us-east-2.amazonaws.com

You can pass object storage in either of these forms:

--store s3://bucket/prefix, --store gs://bucket/prefix, or --store file:///path/to/objects.

--storage TYPE --bucket BUCKET, which is useful for S3-compatible services that expect an endpoint-style bucket URL.

For Cloudflare R2 or another S3-compatible service, keep credentials in the environment used by SmolFS. Do not put access keys in command arguments or logs.

set -a . ./.env set +a

export SMOLFS_HOME=/tmp/smolfs-r2-home VOL="r2demo-$(date +%Y%m%d%H%M%S)"

smolfs init "$VOL" \ --metadata "$SMOLFS_R2_METADATA" \ --storage s3 \ --bucket "$SMOLFS_R2_BUCKET_URL"

Mount and Use the Volume

Mounting makes the volume appear as a normal local directory:

smolfs mount demo ./workspace echo hello > ./workspace/hello.txt cat ./workspace/hello.txt

SmolFS creates the mount directory if it does not exist. After the mount succeeds, programs can read and write files through that directory.

Useful options:

--check-storage asks SmolFS to test object storage access before the mount completes.

--foreground runs the mount process in the foreground instead of starting it in the background.

Flush, Inspect, and Unmount

Run flush when you want a best-effort check that recent writes have reached the mounted filesystem:

smolfs flush demo

Run status to see known volumes:

smolfs status smolfs status demo smolfs status --json

Unmount when the job is done:

smolfs unmount demo

unmount asks SmolFS to flush before detaching the mountpoint. Use smolfs umount demo if you prefer the shorter alias. Add --force when the mountpoint is busy and you want SmolFS to force the unmount.

After unmounting, you can mount the same volume again and read the files:

smolfs mount demo ./workspace cat ./workspace/hello.txt

Commands

Command What it does

smolfs doctor Checks SmolFS storage, local mount support, and configuration.

smolfs init NAME --dev Creates a local development volume.

smolfs init NAME --metadata URL --storage TYPE --bucket BUCKET Creates a cloud volume with explicit metadata and object storage.

smolfs mount NAME PATH Mounts a volume at a local directory.

smolfs flush NAME Probes the mounted volume and syncs a small file through it.

smolfs status [NAME] Shows known volumes and current mountpoints.

smolfs unmount NAME Unmounts a mounted volume and asks SmolFS to flush.

smolfs umount NAME Alias for smolfs unmount NAME.

Every command has its own help page:

smolfs help smolfs init --help

Python SDK

The Python package is SDK-only. Install it with uv:

uv add smolfs

For local development from this checkout:

uv run --isolated --with-editable ./bindings/python python -c "from smolfs import doctor; print(doctor())"

Use the SDK from any Python agent runner:

from pathlib import Path

from smolfs import SmolFS, doctor

report = doctor() if not report["storage_backend"]["found"] or not report["mount_support"]["found"]: raise RuntimeError(f"SmolFS is not ready: {report}")

fs = SmolFS.from_env() volume = fs.ensure_volume("demo", dev=True) mount = fs.mount(volume.name, "./workspace")

workspace = Path(mount.mountpoint) (workspace / "hello.txt").write_text("hello from SmolFS\n")

try: fs.flush(volume.name) finally: fs.unmount(volume.name)

Cloud volumes use the same API with explicit metadata and object storage:

fs.ensure_volume( "agent-workspace", metadata="redis://localhost:6379/1", storage="s3", bucket="https://my-bucket.s3.us-east-2.amazonaws.com", )

For S3-compatible services such as MinIO or Cloudflare R2, pass the service bucket URL and provide ACCESS_KEY and SECRET_KEY in the environment used by SmolFS.

TypeScript SDK

The TypeScript package is a native Node.js binding over the same Rust core. The npm package ships prebuilt native bindings for Linux and macOS on x86_64 and arm64.

Install it with npm:

npm install @celestoai/smolfs

For local development from this checkout, use Node.js 18 or newer:

cd bindings/node npm ci npm run build:debug npm test

Use the SDK from a Node.js agent runner:

import { SmolFS, doctor } from "@celestoai/smolfs"; import { writeFile } from "node:fs/promises"; import { join } from "node:path";

const report = doctor(); if (!report.storageBackend.found || !report.mountSupport.found) { throw new Error(SmolFS is not ready: ${JSON.stringify(report)}); }

const fs = SmolFS.fromEnv(); const volume = fs.ensureVolume({ name: "demo", dev: true }); const mount = fs.mount({ name: volume.name, path: "./workspace" });

try { await writeFile(join(mount.mountpoint, "hello.txt"), "hello from SmolFS\n"); fs.flush(volume.name); } finally { fs.unmount(volume.name); }

Cloud volumes use the same options object:

fs.ensureVolume({ name: "agent-workspace", metadata: "redis://localhost:6379/1", storage: "s3", bucket: "https://my-bucket.s3.us-east-2.amazonaws.com" });

Development

Work from a source checkout when you are changing SmolFS itself or when a CLI release asset has not been published yet.

Build and check the CLI:

cargo build -p smolfs-cli ./target/debug/smolfs doctor

Run the normal quality checks:

cargo fmt --all -- --check cargo clippy --workspace -- -D warnings cargo test --workspace

Run the R2-style lifecycle from this checkout:

cargo build -p smolfs-cli

set -a . ./.env set +a

export SMOLFS_HOME=/tmp/smolfs-r2-home VOL="r2demo-$(date +%Y%m%d%H%M%S)" MOUNT="/tmp/smolfs-r2-workspace"

./target/debug/smolfs init "$VOL" \ --metadata "$SMOLFS_R2_METADATA" \ --storage s3 \ --bucket "$SMOLFS_R2_BUCKET_URL"

./target/debug/smolfs mount "$VOL" "$MOUNT" echo "hello from smolfs r2" > "$MOUNT/hello.txt" ./target/debug/smolfs flush "$VOL" ./target/debug/smolfs unmount "$VOL" ./target/debug/smolfs mount "$VOL" "$MOUNT" cat "$MOUNT/hello.txt"

Run the MinIO integration test path when the SmolFS storage backend, Redis, and a MinIO bucket are available:

SMOLFS_RUN_INTEGRATION=1 cargo test --workspace -- --nocapture

Build the Python wheel:

uvx maturin build --manifest-path bindings/python/Cargo.toml --interpreter python

Develop the Python binding locally:

uvx maturin develop --manifest-path bindings/python/Cargo.toml

Test the TypeScript SDK:

cd bindings/node npm ci npm test

Security and Reliability

SmolFS stores agent workspace data outside the sandbox lifecycle. Treat it like durable infrastructure.

Do not log credentials, S3 access keys, Redis URLs with secrets, or mount tokens.

Prefer explicit object-store configuration over hidden global state.

Make mount and unmount behavior idempotent where possible.

Fail loudly on missing storage backend, missing metadata URLs, missing object-store config, or missing local mount support.

Avoid changes that weaken persistence guarantees without calling them out.

Releases

The smolfs command is built from the Rust CLI crate. The GitHub workflow at .github/workflows/publish-cli.yml builds Linux and macOS release binaries for x86_64 and arm64 targets, smoke-tests smolfs --help, and attaches tarballs to v* GitHub releases. Pushes to main publish a rolling dev prerelease a

[truncated for AI cost control]