Server data from the Official MCP Registry
PostgreSQL-backed virtual filesystem for agents: session isolation, shared stores, POSIX ops, RLS.
PostgreSQL-backed virtual filesystem for agents: session isolation, shared stores, POSIX ops, RLS.
Valid MCP server (2 strong, 3 medium validity signals). 5 known CVEs in dependencies (0 critical, 4 high severity) Package registry verified. Imported from the Official MCP Registry.
6 files analyzed · 6 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Set these up before or after installing:
Environment variable: DATABASE_URL
Environment variable: VFS_AUTO_INIT
Environment variable: VFS_SESSION_ID
Environment variable: VFS_ENABLE_RLS
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-lu-zhengda-virtual-fs": {
"env": {
"DATABASE_URL": "your-database-url-here",
"VFS_AUTO_INIT": "your-vfs-auto-init-here",
"VFS_ENABLE_RLS": "your-vfs-enable-rls-here",
"VFS_SESSION_ID": "your-vfs-session-id-here"
},
"args": [
"-y",
"mcp-virtual-fs"
],
"command": "npx"
}
}
}From the project's GitHub README.
An MCP server that provides AI agents with a persistent, PostgreSQL-backed virtual filesystem. Supports session-isolated file operations, cross-session shared stores, glob/grep search, and Row Level Security — all exposed as standard Model Context Protocol tools.
Works with any MCP client: Claude Desktop, Claude Code, Cursor, Windsurf, Cline, and others.
read, write, append, stat, ls, mkdir, rm, mv, glob, grep, stores**/*.ts) or search content by regex, powered by PostgreSQL trigram indexesVFS_AUTO_INIT=trueAgents work well with filesystems for context management, but coupling storage to the agent runtime means data is lost when pods restart or containers are recycled. This MCP server decouples storage from runtime by moving file operations to PostgreSQL — giving agents persistent, isolated, and searchable file storage without touching the host filesystem.
pg_trgm extension — included in most distributions)# Using Docker
docker run -d --name vfs-postgres \
-e POSTGRES_DB=vfs \
-e POSTGRES_PASSWORD=postgres \
-p 5432:5432 \
postgres:16-alpine
Add to your MCP client config (e.g., Claude Desktop claude_desktop_config.json or Claude Code .mcp.json):
{
"mcpServers": {
"virtual-fs": {
"command": "npx",
"args": ["-y", "mcp-virtual-fs"],
"env": {
"DATABASE_URL": "postgresql://postgres:postgres@localhost:5432/vfs",
"VFS_AUTO_INIT": "true"
}
}
}
}
That's it. VFS_AUTO_INIT=true creates the tables on first run.
Tool names are short POSIX-style names:
write({ path: "/notes/todo.md", content: "# My Tasks\n- Ship feature" })
read({ path: "/notes/todo.md" })
ls({ path: "/notes" })
glob({ pattern: "**/*.md" })
grep({ pattern: "TODO" })
All tools return structured JSON responses.
| Tool | Parameters | Returns | Description |
|---|---|---|---|
read | path | {content, size} | Read file contents |
write | path, content | {path, size, has_parents} | Write file (creates parents automatically) |
append | path, content | {path, appended_bytes} | Append to file (creates if missing) |
stat | path | {exists, type?, size?, children?} | Check existence and get metadata |
ls | path | {entries: [{name, type}]} | List directory (dirs first, then alphabetical) |
mkdir | path | {path, already_existed} | Create directory and parents (mkdir -p) |
rm | path | {path, deleted} | Remove file or directory recursively |
mv | source, destination | {source, destination} | Move/rename file or directory |
glob | pattern | {files, count} | Find files by glob (e.g., **/*.ts, **/*.{js,ts}) |
grep | pattern, path_filter? | {matches, count} | Search file contents by regex |
stores | (none) | {stores, count} | List all persistent store names |
All tools (except stores) accept an optional store parameter for cross-session persistent storage.
Sessions are handled automatically — no session ID in tool parameters.
How it works:
| Transport | Session identity | Behavior |
|---|---|---|
| stdio | Auto-generated UUID per process | Each MCP connection = unique session |
| HTTP/SSE | Transport-provided sessionId | MCP protocol handles it |
| Any | VFS_SESSION_ID env var | Deterministic/resumable sessions |
Priority: transport sessionId > VFS_SESSION_ID env var > auto-generated UUID.
To resume a previous session across process restarts, set a deterministic session ID:
{
"env": {
"DATABASE_URL": "postgresql://...",
"VFS_SESSION_ID": "my-agent-session-1"
}
}
Named stores persist across sessions. Any session can read/write to a store by passing the store parameter:
// Session A writes to a store
write({ path: "/context.md", content: "project notes", store: "agent-memory" })
// Session B (days later) reads from the same store
read({ path: "/context.md", store: "agent-memory" })
// Without `store`, operations target the session's own namespace
write({ path: "/scratch.txt", content: "session-only data" })
// List all available stores
stores()
Stores are auto-created on first use.
| Variable | Required | Default | Description |
|---|---|---|---|
DATABASE_URL | Yes | — | PostgreSQL connection string |
VFS_AUTO_INIT | No | false | Auto-create tables on startup |
VFS_SESSION_ID | No | random UUID | Deterministic session ID |
VFS_ENABLE_RLS | No | false | Enable Row Level Security |
VFS_STORAGE_BACKEND | No | postgres | Storage backend type |
If you prefer to manage the schema yourself instead of using VFS_AUTO_INIT:
psql $DATABASE_URL -f sql/schema.sql
RLS provides database-enforced session isolation. Even if application code has a bug that omits a WHERE session_id = clause, PostgreSQL itself prevents cross-session access.
# Run after schema.sql
psql $DATABASE_URL -f sql/rls.sql
# Update the vfs_app password
psql $DATABASE_URL -c "ALTER ROLE vfs_app PASSWORD 'your-secure-password'"
Then configure the MCP server to connect as vfs_app:
{
"env": {
"DATABASE_URL": "postgresql://vfs_app:your-secure-password@localhost:5432/vfs",
"VFS_ENABLE_RLS": "true"
}
}
git clone https://github.com/lu-zhengda/mcp-virtual-fs.git
cd mcp-virtual-fs
npm install
npm run build
| Command | Description |
|---|---|
npm run build | Compile TypeScript |
npm test | Run all tests (requires Docker) |
npm run test:unit | Run unit tests only |
npm run test:integration | Run integration tests only |
npm run lint | Run ESLint |
npm run lint:fix | Auto-fix lint issues |
npm run dev | Run with tsx (no build step) |
Tests use testcontainers to spin up real PostgreSQL instances in Docker. No mocks — the integration tests exercise actual SQL queries, trigram indexes, and RLS policies.
# Requires Docker running
npm test
Ephemeral sessions can be cleaned up periodically:
DELETE FROM vfs_sessions
WHERE is_persistent = false
AND created_at < now() - interval '7 days';
The ON DELETE CASCADE on vfs_nodes handles file cleanup automatically. Persistent stores (created via the store parameter) are never affected.
MIT
Be the first to review this server!
by Modelcontextprotocol · Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno · Developer Tools
Toleno Network MCP Server — Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace · Developer Tools
Create, build, and publish Python MCP servers to PyPI — conversationally.
by Microsoft · Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption
by mcp-marketplace · Developer Tools
Scaffold, build, and publish TypeScript MCP servers to npm — conversationally
by mcp-marketplace · Finance
Free stock data and market news for any MCP-compatible AI assistant.