协议修订: 2025-11-25
用户交互模型
具体实现可以自由地通过任何符合其需求的界面模式展示日志——协议本身不强制要求任何特定的用户交互模型。功能
发出日志消息通知的服务器必须 (MUST) 声明logging 能力
日志级别
该协议遵循 RFC 5424 中指定的标准 syslog 严重性级别| 级别 | 描述 | 示例用例 |
|---|---|---|
| debug | 详细的调试信息 | 函数入口/出口点 |
| info | 常规信息性消息 | 操作进度更新 |
| notice | 普通但重要的事件 | 配置更改 |
| warning | 警告情况 | 弃用功能的使用 |
| error | 错误条件 | 操作失败 |
| critical | 关键状况 | 系统组件故障 |
| alert | 必须立即采取行动 | 检测到数据损坏 |
| emergency | 系统不可用 | 系统完全崩溃 |
协议消息
设置日志级别
要配置最低日志级别,客户端可以 (MAY) 发送logging/setLevel 请求: 请求:日志消息通知
服务器使用notifications/message 通知发送日志消息
消息流
错误处理
服务器应该为常见的失败情况返回标准的 JSON-RPC 错误- 无效的日志级别:
-32602(无效参数) - 配置错误:
-32603(内部错误)
实现注意事项
-
服务器**应该**
- 限制日志消息速率
- 在数据字段中包含相关上下文
- 使用一致的日志记录器名称
- 移除敏感信息
-
客户端可以 (MAY)
- 在 UI 中展示日志消息
- 实现日志过滤/搜索
- 以视觉方式展示严重程度
- 持久化日志消息
安全性
-
日志消息不得 (MUST NOT) 包含
- 凭据或机密信息
- 个人身份信息
- 可能辅助攻击的内部系统细节
-
实现应当 (SHOULD)
- 限制消息速率
- 验证所有数据字段
- 控制日志访问
- 监控敏感内容