Skip to main content

Documentation Index

Fetch the complete documentation index at: https://mcp.zhcndoc.com/llms.txt

Use this file to discover all available pages before exploring further.

已弃用:自协议版本 DRAFT-2026-v1 起,Logging 功能已弃用。根据 SEP-2596 中概述的弃用策略,自 DRAFT-2026-v1 起 1 年内发布的任何 MCP 版本仍将继续支持该功能。
Model Context Protocol(MCP)为服务器向客户端发送结构化日志消息提供了一种标准化方式。客户端通过 _meta 按请求控制日志详细程度,而服务器会发送包含严重性级别、可选记录器名称以及任意可 JSON 序列化数据的通知。

用户交互模型

实现可以通过任何适合其需求的接口模式暴露日志—协议本身并不强制要求任何特定的用户交互模型。

能力

发出日志消息通知的服务器 必须 声明 logging 能力:
{
  "capabilities": {
    "logging": {}
  }
}

日志级别

协议遵循 RFC 5424 中指定的标准 syslog 严重性级别:
级别描述示例用例
debug详细调试信息函数入口/出口点
info一般信息消息操作进度更新
notice正常但显著的事件配置更改
warning警告条件弃用功能使用
error错误条件操作失败
critical严重条件系统组件故障
alert必须立即采取行动检测到数据损坏
emergency系统不可用完全系统故障

请求日志消息

按请求的日志级别

要接收特定请求的日志消息,请在该请求的 _meta 中包含 io.modelcontextprotocol/logLevel。对于未包含此字段的请求,服务器 不得 发送 notifications/message 当该字段存在时,服务器 可以 在该请求的响应流上、最终响应之前,发送 所请求级别及以上的 notifications/message 通知。notifications/message 具有请求作用域:服务器 不得subscriptions/listen 流上,或任何非承载设置日志级别之请求响应的流上交付它。

协议消息

日志消息通知

服务器使用 notifications/message 通知发送日志消息:
{
  "jsonrpc": "2.0",
  "method": "notifications/message",
  "params": {
    "level": "error",
    "logger": "database",
    "data": {
      "error": "连接失败",
      "details": {
        "host": "localhost",
        "port": 5432
      }
    }
  }
}

错误处理

如果请求的 _meta 中携带的 io.modelcontextprotocol/logLevel 值不是可识别的 日志级别,服务器 应该 使用标准 JSON-RPC 错误拒绝该请求:
  • 无效日志级别:-32602(Invalid params)
  • 内部错误:-32603(Internal error)

实现注意事项

  1. 服务器 应该
    • 限制日志消息速率
    • 在数据字段中包含相关上下文
    • 使用一致的记录器名称
    • 移除敏感信息
  2. 客户端 可以
    • 在 UI 中展示日志消息
    • 实现日志过滤/搜索
    • 可视化显示严重性
    • 持久化日志消息

安全性

  1. 日志消息 不得 包含:
    • 凭证或秘密
    • 个人身份信息
    • 可能协助攻击的内部系统细节
  2. 实现 应该
    • 限制消息速率
    • 验证所有数据字段
    • 控制日志访问
    • 监控敏感内容