docs/BUILTIN_MCP_SERVICES.md
内置 MCP 服务是系统级别的 MCP(Model Context Protocol)服务配置,对所有租户可见,但敏感信息会被隐藏,且不可编辑或删除。内置 MCP 服务通常用于提供系统默认的外部工具和资源接入,确保所有租户都能使用统一的 MCP 服务。
| 特性 | 内置模型 | 内置 MCP 服务 |
|---|---|---|
| 标识字段 | is_builtin | is_builtin |
| 可见范围 | 所有租户 | 所有租户 |
| 隐藏信息 | API Key、Base URL | URL、认证配置、Headers、环境变量 |
| 编辑保护 | 不可编辑/删除 | 不可编辑/删除 |
| 前端标签 | 显示"内置"标签 | 显示"内置"标签 |
| 启停控制 | — | 禁用开关(始终启用) |
内置 MCP 服务需要通过数据库直接插入。以下是添加内置 MCP 服务的步骤:
首先,确保你已经有了要设置为内置 MCP 服务的配置信息,包括:
sse 或 http-streamable支持的传输方式:
sse:Server-Sent Events,推荐用于流式体验http-streamable:HTTP Streamable,标准 HTTP 兼容注意:出于安全考虑,
stdio传输方式在服务端已被禁用。
使用以下 SQL 语句插入内置 MCP 服务:
-- 示例:插入一个 SSE 传输方式的内置 MCP 服务
INSERT INTO mcp_services (
id,
tenant_id,
name,
description,
enabled,
transport_type,
url,
auth_config,
advanced_config,
is_builtin
) VALUES (
'builtin-mcp-001', -- 使用固定ID,建议使用 builtin-mcp- 前缀
10000, -- 租户ID(使用第一个租户)
'Web Search', -- 服务名称
'内置 Web 搜索 MCP 服务', -- 描述
true, -- 启用状态
'sse', -- 传输方式
'https://mcp.example.com/sse', -- 服务地址
'{"api_key": "your-api-key"}'::jsonb, -- 认证配置
'{"timeout": 30, "retry_count": 3, "retry_delay": 1}'::jsonb, -- 高级配置
true -- 标记为内置服务
) ON CONFLICT (id) DO NOTHING;
-- 示例:插入一个 HTTP Streamable 传输方式的内置 MCP 服务
INSERT INTO mcp_services (
id,
tenant_id,
name,
description,
enabled,
transport_type,
url,
headers,
auth_config,
advanced_config,
is_builtin
) VALUES (
'builtin-mcp-002',
10000,
'Code Interpreter',
'内置代码解释器 MCP 服务',
true,
'http-streamable',
'https://mcp.example.com/stream',
'{"X-Custom-Header": "value"}'::jsonb,
'{"token": "your-bearer-token"}'::jsonb,
'{"timeout": 60, "retry_count": 2, "retry_delay": 2}'::jsonb,
true
) ON CONFLICT (id) DO NOTHING;
执行以下 SQL 查询验证内置 MCP 服务是否成功插入:
SELECT id, name, transport_type, enabled, is_builtin
FROM mcp_services
WHERE is_builtin = true
ORDER BY created_at;
builtin-mcp-{序号} 的格式,例如 builtin-mcp-001、builtin-mcp-002auth_config、advanced_config、headers 等字段必须是有效的 JSON 格式ON CONFLICT (id) DO NOTHING 确保重复执行不会报错sse 和 http-streamable,stdio 已被禁用如果你已经有一个 MCP 服务,想将其设置为内置服务,可以使用 UPDATE 语句:
UPDATE mcp_services
SET is_builtin = true
WHERE id = '服务ID' AND name = '服务名称';
如果需要移除内置标记(恢复为普通 MCP 服务),执行:
UPDATE mcp_services
SET is_builtin = false
WHERE id = '服务ID';
注意:移除内置标记后,该 MCP 服务将恢复为普通服务,可以被编辑和删除。