mcpfirebird
数据与存储by luancamara
轻松执行查询、浏览 schema 并读取表数据,借助执行计划、索引建议和表统计诊断性能,同时提供备份、恢复、校验与健康检查保障数据库。
什么是 mcpfirebird?
轻松执行查询、浏览 schema 并读取表数据,借助执行计划、索引建议和表统计诊断性能,同时提供备份、恢复、校验与健康检查保障数据库。
README
MCP Firebird
Implementation of Anthropic's MCP (Model Context Protocol) for Firebird databases.
Example Usage
https://github.com/user-attachments/assets/e68e873f-f87b-4afd-874f-157086e223af
What is MCP Firebird?
MCP Firebird is a server that implements Anthropic's Model Context Protocol (MCP) for Firebird SQL databases. It allows Large Language Models (LLMs) like Claude to access, analyze, and manipulate data in Firebird databases securely and in a controlled manner.
Key Features
- SQL Queries: Execute SQL queries on Firebird databases
- Schema Analysis: Get detailed information about tables, columns, and relationships
- Database Management: Perform backup, restore, and validation operations
- Performance Analysis: Analyze query performance and suggest optimizations
- Multiple Transports: Supports STDIO, SSE (Server-Sent Events), and Streamable HTTP transports
- Modern Protocol Support: Full support for MCP Streamable HTTP (2025-03-26) and legacy SSE
- Unified Server: Automatic protocol detection and backwards compatibility
- Claude Integration: Works seamlessly with Claude Desktop and other MCP clients
- VSCode Integration: Works with GitHub Copilot in Visual Studio Code
- Session Management: Robust session handling with automatic cleanup and configurable timeouts
- Security: Includes SQL query validation and security configuration options
- Dual Driver Support: Choose between simple installation (default) or native driver with wire encryption support
🚀 Quick Start with Smithery (Recommended for Cloud Deployment)
Deploy MCP Firebird to the cloud in under 5 minutes!
Smithery is the easiest way to deploy MCP Firebird to production:
✅ One-click deployment - No infrastructure setup required ✅ Automatic scaling - Handles traffic spikes automatically ✅ Built-in monitoring - Track usage and performance ✅ Secure credentials - Encrypted environment variables ✅ Auto-updates - Always running the latest version ✅ Global CDN - Low latency worldwide
How to Deploy on Smithery
- Visit smithery.ai
- Connect your GitHub account
- Select the
mcpFirebirdrepository - Configure your Firebird database connection:
yaml
host: "your-firebird-server.com" port: 3050 database: "/path/to/database.fdb" user: "SYSDBA" password: "your-secure-password" useNativeDriver: true # Enable wire encryption (optional) logLevel: "info" - Click Deploy - Done! ✨
Your MCP Firebird server will be available at:
https://server.smithery.ai/your-username/mcp-firebird
Using with AI Clients
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
import { StreamableHTTPClientTransport } from "@modelcontextprotocol/sdk/client/streamableHttp.js";
const transport = new StreamableHTTPClientTransport(
"https://server.smithery.ai/your-username/mcp-firebird"
);
const client = new Client({
name: "my-ai-app",
version: "1.0.0"
});
await client.connect(transport);
📚 For detailed Smithery deployment instructions, see SMITHERY_DEPLOYMENT.md
🔒 Wire Encryption Support
MCP Firebird supports two driver options:
| Driver | Installation | Wire Encryption | Use Case |
|---|---|---|---|
| Pure JavaScript (default) | ✅ Simple (npx) | ❌ No | Most users, quick setup |
| Native Driver (optional) | ⚠️ Complex (requires build tools) | ✅ Yes | Enterprise, security required |
Quick Start (Default - No Wire Encryption)
npx mcp-firebird@alpha --database=/path/to/database.fdb
Advanced (With Wire Encryption Support)
⚠️ CRITICAL: npx does NOT work with the native driver. You MUST install globally.
⚠️ IMPORTANT: Wire encryption must be configured on the Firebird server (firebird.conf), not on the client.
Server Configuration (required first):
# In firebird.conf on the server
WireCrypt = Required # or Enabled
Client Installation (MUST be global):
# Step 1: Install build tools
# Windows: Visual Studio Build Tools (https://visualstudio.microsoft.com/downloads/)
# Linux: sudo apt-get install build-essential python3 firebird-dev
# macOS: xcode-select --install && brew install firebird
# Step 2: Install MCP Firebird globally
npm install -g mcp-firebird@alpha
# Step 3: Install native driver globally
npm install -g node-firebird-driver-native
# Step 4: Run directly (WITHOUT npx)
mcp-firebird --use-native-driver \
--database=/path/to/database.fdb \
--host=localhost \
--user=SYSDBA \
--password=masterkey
Why not npx? When npx runs a package from its temporary cache, it cannot access globally installed modules like node-firebird-driver-native. Both packages must be installed globally in the same location.
📚 For detailed installation instructions, see:
- Smithery CLI Installation Guide - ⭐ Recommended for local setup
- Native Driver Installation Guide - Step-by-step for Windows/Linux/macOS
- Wire Encryption Guide
- Advanced Installation Guide
🖥️ Local Installation with Smithery CLI
⭐ Recommended for local AI clients (Claude Desktop, Cursor, etc.)
The Smithery CLI provides the easiest way to install and configure MCP Firebird for local use:
Quick Install
# Interactive installation (prompts for configuration)
npx -y @smithery/cli@latest install mcp-firebird --client claude
# Pre-configured installation (skip prompts)
npx -y @smithery/cli@latest install mcp-firebird --client claude --config '{
"database": "/path/to/database.fdb",
"user": "SYSDBA",
"password": "masterkey",
"useNativeDriver": false
}'
Features
- ✅ One-command installation - No manual configuration needed
- ✅ Multiple clients - Works with Claude Desktop, Cursor, and more
- ✅ Interactive setup - Prompts for all required settings
- ✅ Auto-configuration - Automatically configures your AI client
- ✅ Easy management - List, inspect, and uninstall servers easily
Common Commands
# List installed servers
npx @smithery/cli list servers --client claude
# Inspect server configuration
npx @smithery/cli inspect mcp-firebird
# Uninstall server
npx @smithery/cli uninstall mcp-firebird --client claude
📖 Full Guide: Smithery CLI Installation Guide
Manual Installation
Stable Version
# Global installation (stable)
npm install -g mcp-firebird
# Run the server
npx mcp-firebird --database /path/to/database.fdb
# Or use specific stable version
npm install -g mcp-firebird@2.2.3
Stable Features (v2.2.3):
- 🐛 FIXED: SSE JSON parsing bug - resolves "Invalid message: [object Object]" errors
- ✨ Streamable HTTP transport support (MCP 2025-03-26)
- 🔄 Unified server with automatic protocol detection
- 📊 Enhanced session management and monitoring
- 🛠️ Modern MCP SDK integration (v1.13.2)
- 🔧 Improved error handling and logging
- 🧪 Comprehensive test suite with 9+ tests for SSE functionality
Alpha Version (Latest Features)
# Install alpha version with latest features
npm install -g mcp-firebird@alpha
# Or use specific alpha version
npm install -g mcp-firebird@2.4.0-alpha.0
Alpha Features (v2.4.0-alpha.0):
- � NEW: Ready for next development cycle
- ✨ All stable features from v2.2.3 included
- 🔄 Unified server with automatic protocol detection
- 📊 Enhanced session management and monitoring
- 🛠️ Modern MCP SDK integration (v1.13.2)
- 🔧 Improved error handling and logging
- 🧪 Comprehensive test suite with 9+ tests for SSE functionality
- 📚 Enhanced documentation with troubleshooting guides
Note: The SSE JSON parsing bug fix is now available in stable v2.2.3
For backup/restore operations, you'll need to install the Firebird client tools. See Complete Installation for more details.
For VSCode and GitHub Copilot integration, see VSCode Integration.
Basic Usage
With Claude Desktop
-
Edit the Claude Desktop configuration:
bashcode $env:AppData\Claude\claude_desktop_config.json # Windows code ~/Library/Application\ Support/Claude/claude_desktop_config.json # macOS -
Add the MCP Firebird configuration:
json{ "mcpServers": { "mcp-firebird": { "command": "npx", "args": [ "mcp-firebird", "--host", "localhost", "--port", "3050", "--database", "C:\\path\\to\\database.fdb", "--user", "SYSDBA", "--password", "masterkey" ], "type": "stdio" } } } -
Restart Claude Desktop
Transport Configuration
MCP Firebird supports multiple transport protocols to accommodate different client needs and deployment scenarios.
STDIO Transport (Default)
The STDIO transport is the standard method for Claude Desktop integration:
{
"mcpServers": {
"mcp-firebird": {
"command": "npx",
"args": [
"mcp-firebird",
"--database", "C:\\path\\to\\database.fdb",
"--user", "SYSDBA",
"--password", "masterkey"
],
"type": "stdio"
}
}
}
SSE Transport (Server-Sent Events)
SSE transport allows the server to run as a web service, useful for web applications and remote access:
Basic SSE Configuration
# Start SSE server on default port 3003
npx mcp-firebird --transport-type sse --database /path/to/database.fdb
# Custom port and full configuration
npx mcp-firebird \
--transport-type sse \
--sse-port 3003 \
--database /path/to/database.fdb \
--host localhost \
--port 3050 \
--user SYSDBA \
--password masterkey
Environment Variables for SSE
# Set environment variables
export TRANSPORT_TYPE=sse
export SSE_PORT=3003
export DB_HOST=localhost
export DB_PORT=3050
export DB_DATABASE=/path/to/database.fdb
export DB_USER=SYSDBA
export DB_PASSWORD=masterkey
# Start server
npx mcp-firebird
SSE Client Connection
Once the SSE server is running, clients can connect to:
- SSE Endpoint:
http://localhost:3003/sse - Messages Endpoint:
http://localhost:3003/messages - Health Check:
http://localhost:3003/health
Streamable HTTP Transport (Modern)
The latest MCP protocol supporting bidirectional communication:
# Start with Streamable HTTP
npx mcp-firebird --transport-type http --http-port 3003 --database /path/to/database.fdb
Unified Transport (Recommended)
Supports both SSE and Streamable HTTP protocols simultaneously with automatic detection:
# Start unified server (supports both SSE and Streamable HTTP)
npx mcp-firebird --transport-type unified --http-port 3003 --database /path/to/database.fdb
Unified Server Endpoints
- SSE (Legacy):
http://localhost:3003/sse - Streamable HTTP (Modern):
http://localhost:3003/mcp - Auto-Detection:
http://localhost:3003/mcp-auto - Health Check:
http://localhost:3003/health
Configuration Examples
Development Setup (SSE)
npx mcp-firebird \
--transport-type sse \
--sse-port 3003 \
--database ./dev-database.fdb \
--user SYSDBA \
--password masterkey
Production Setup (Unified)
npx mcp-firebird \
--transport-type unified \
--http-port 3003 \
--database /var/lib/firebird/production.fdb \
--host db-server \
--port 3050 \
--user APP_USER \
--password $DB_PASSWORD
Docker with SSE
docker run -d \
--name mcp-firebird \
-p 3003:3003 \
-e TRANSPORT_TYPE=sse \
-e SSE_PORT=3003 \
-e DB_DATABASE=/data/database.fdb \
-v /path/to/database:/data \
purodelhi/mcp-firebird:latest
Advanced SSE Configuration
Session Management
Configure session timeouts and limits:
# Environment variables for session management
export SSE_SESSION_TIMEOUT_MS=1800000 # 30 minutes
export MAX_SESSIONS=1000 # Maximum concurrent sessions
export SESSION_CLEANUP_INTERVAL_MS=60000 # Cleanup every minute
npx mcp-firebird --transport-type sse
CORS Configuration
For web applications, configure CORS settings:
# Allow specific origins
export CORS_ORIGIN="https://myapp.com,https://localhost:3000"
export CORS_METHODS="GET,POST,OPTIONS"
export CORS_HEADERS="Content-Type,mcp-session-id"
npx mcp-firebird --transport-type sse
SSL/TLS Support
For production deployments, use a reverse proxy like nginx:
server {
listen 443 ssl;
server_name mcp-firebird.yourdomain.com;
ssl_certificate /path/to/cert.pem;
ssl_certificate_key /path/to/key.pem;
location / {
proxy_pass http://localhost:3003;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
Troubleshooting
Firebird Connection Issues
-
Wire Encryption Incompatibility (Firebird 3.0+) ⚠️ CRITICAL
Error:
Incompatible wire encryption levels requested on client and serverIMPORTANT: The
node-firebirdlibrary does NOT support Firebird 3.0+ wire encryption. The--wire-cryptparameter does NOT work.ONLY Solution: You MUST disable wire encryption on the Firebird server:
For Firebird 3.0, add to
firebird.conf:confWireCrypt = Disabled AuthServer = Srp, Legacy_AuthFor Firebird 4.0+, add to
firebird.conf:confWireCrypt = Disabled AuthServer = Srp256, Srp, Legacy_AuthFor Firebird 5.0 Docker:
yamlenvironment: FIREBIRD_CONF_WireCrypt: Disabled FIREBIRD_CONF_AuthServer: Srp256, SrpIf you cannot change server configuration, see Wire Encryption Limitation for alternatives.
-
Database Path Issues on Linux/Unix
Problem: Remote connection strings or Unix paths not working
Solution: This is fixed in v2.4.0-alpha.1+. The following paths now work correctly:
- Remote:
server:/path/to/database.fdb - Unix absolute:
/var/lib/firebird/database.fdb - IP-based:
192.168.1.100:/data/db.fdb
- Remote:
-
I/O Error with Mixed-Case Paths on Windows
Error:
I/O error during CreateFile (open) operationProblem: Database path with mixed case (e.g.,
C:\MyData\database.fdb) causes errorsWorkarounds:
- Use all-uppercase paths:
C:\MYDATA\DATABASE.FDB - Use forward slashes:
C:/MyData/database.fdb - See Wire Encryption Fix Documentation for more details
- Use all-uppercase paths:
SSE Connection Issues
-
Connection Refused
bash# Check if server is running curl http://localhost:3003/health # Check port availability netstat -an | grep 3003 -
Session Timeout
bash# Increase session timeout export SSE_SESSION_TIMEOUT_MS=3600000 # 1 hour -
CORS Errors
bash# Allow all origins (development only) export CORS_ORIGIN="*" -
Memory Issues
bash# Reduce max sessions export MAX_SESSIONS=100 # Enable more frequent cleanup export SESSION_CLEANUP_INTERVAL_MS=30000 -
JSON Parsing Issues (Fixed in v2.3.0-alpha.1+)
bash# If experiencing "Invalid message: [object Object]" errors, # upgrade to the latest alpha version: npm install mcp-firebird@alpha # Or use the latest alpha directly: npx mcp-firebird@alpha --transport-type sseNote: Versions prior to 2.3.0-alpha.1 had a bug where POST requests to
/messagesendpoint failed to parse JSON body correctly. This has been fixed with improved middleware handling for bothapplication/jsonandtext/plaincontent types.
Monitoring and Logging
# Enable debug logging
export LOG_LEVEL=debug
# Monitor server health
curl http://localhost:3003/health | jq
# Check active sessions
curl http://localhost:3003/health | jq '.sessions'
Quick Installation via Smithery
To install MCP Firebird for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @PuroDelphi/mcpFirebird --client claude
Documentation
For more detailed information, check the following documents:
Getting Started
- Complete Installation
- Configuration Options
- Available Tools
- Resources, Tools, and Prompts Reference - Complete guide to all MCP capabilities
Transport Protocols
Integration Guides
Advanced Topics
- Session Management
- Security
- Performance Tuning
- Troubleshooting
- Wire Encryption Fix - Firebird 3.0+ compatibility and Linux path fix
- SSE JSON Parsing Fix - Details about the v2.3.0-alpha.1 bug fix
Examples and Use Cases
Support the Project
Donations
If you find MCP Firebird useful for your work or projects, please consider supporting its development through a donation. Your contributions help maintain and improve this tool.
- GitHub Sponsors: Sponsor @PuroDelphi
- PayPal: Donate via PayPal
Hire Our AI Agents
Another great way to support this project is by hiring our AI agents through Asistentes Autónomos. We offer specialized AI assistants for various business needs, helping you automate tasks and improve productivity.
Priority Support
⭐ Donors, sponsors, and clients receive priority support and assistance with issues, feature requests, and implementation guidance. While we strive to help all users, those who support the project financially will receive faster response times and dedicated assistance.
Your support is greatly appreciated and helps ensure the continued development of MCP Firebird!
License
This project is licensed under the MIT License - see the LICENSE file for details.
常见问题
mcpfirebird 是什么?
轻松执行查询、浏览 schema 并读取表数据,借助执行计划、索引建议和表统计诊断性能,同时提供备份、恢复、校验与健康检查保障数据库。
相关 Skills
技术栈评估
by alirezarezvani
对比框架、数据库和云服务,结合 5 年 TCO、安全风险、生态活力与迁移复杂度做量化评估,适合技术选型、栈升级和替换路线决策。
✎ 帮你系统比较技术栈优劣,不只看功能,还把TCO、安全性和生态健康度一起量化,选型和迁移决策更稳。
资深数据工程师
by alirezarezvani
聚焦生产级数据工程,覆盖 ETL/ELT、批处理与流式管道、数据建模、Airflow/dbt/Spark 优化和数据质量治理,适合设计数据架构、搭建现代数据栈与排查性能问题。
✎ 复杂数据管道、ETL/ELT 和治理难题交给它,凭 Spark、Airflow、dbt 等现代数据栈经验,能更稳地搭起可扩展的数据基础设施。
迁移架构师
by alirezarezvani
为数据库、API 与基础设施迁移制定分阶段零停机方案,提前校验兼容性与风险,生成回滚策略、验证关卡和时间线,适合复杂系统平滑切换。
✎ 做数据库与存储迁移时,用它统一梳理表结构和数据搬迁流程,架构视角更完整,复杂迁移也更稳。
相关 MCP Server
SQLite 数据库
编辑精选by Anthropic
SQLite 是让 AI 直接查询本地数据库进行数据分析的 MCP 服务器。
✎ 这个服务器解决了 AI 无法直接访问 SQLite 数据库的问题,适合需要快速分析本地数据集的开发者。不过,作为参考实现,它可能缺乏生产级的安全特性,建议在受控环境中使用。
PostgreSQL 数据库
编辑精选by Anthropic
PostgreSQL 是让 Claude 直接查询和管理你的数据库的 MCP 服务器。
✎ 这个服务器解决了开发者需要手动编写 SQL 查询的痛点,特别适合数据分析师或后端开发者快速探索数据库结构。不过,由于是参考实现,生产环境使用前务必评估安全风险,别指望它能处理复杂事务。
Firecrawl 智能爬虫
编辑精选by Firecrawl
Firecrawl 是让 AI 直接抓取网页并提取结构化数据的 MCP 服务器。
✎ 它解决了手动写爬虫的麻烦,让 Claude 能直接访问动态网页内容。最适合需要实时数据的研究者或开发者,比如监控竞品价格或抓取新闻。但要注意,它依赖第三方 API,可能涉及隐私和成本问题。