跳转到内容

服务器指令覆盖

自定义模板最强大的功能之一是能够使用 Handlebars 逻辑覆盖、过滤或自定义服务器指令。这使您可以完全控制如何向 LLM 呈现服务器指令。

基本服务器指令覆盖模式

1. 完全替换服务器指令

您可以用自己的自定义内容替换原始服务器指令:

markdown
{{#each servers}}
{{#if hasInstructions}}
<{{name}}>
{{#if (eq name "problematic-server")}}

# {{name}} 的自定义指令

此服务器已使用简化指令进行自定义。
使用这些工具:tool1、tool2、tool3
{{else}}
{{instructions}}
{{/if}}
</{{name}}>
{{/if}}
{{/each}}

2. 过滤特定服务器

通过添加条件完全跳过某些服务器:

markdown
{{#each servers}}
{{#unless (eq name "unwanted-server")}}
{{#if hasInstructions}}
<{{name}}>
{{instructions}}
</{{name}}>
{{/if}}
{{/unless}}
{{/each}}

3. 为服务器指令添加前缀或后缀

使用附加上下文增强服务器指令:

markdown
{{#each servers}}
{{#if hasInstructions}}
<{{name}}>
⚠️ **服务器:{{name}}** - 在生产环境中谨慎使用

{{instructions}}

📝 **注意**:所有 {{name}} 操作都会记录用于审计。
</{{name}}>
{{/if}}
{{/each}}

4. 基于服务器名称的条件指令

根据服务器类型或命名模式进行不同处理:

markdown
{{#each servers}}
{{#if hasInstructions}}
<{{name}}>
{{#if (startsWith name "test-")}}

# 测试环境服务器:{{name}}

⚠️ 这是一个测试服务器。结果可能不可靠。

{{instructions}}
{{else if (startsWith name "prod-")}}

# 生产环境服务器:{{name}}

✅ 这是一个生产服务器。所有操作都受到监控。

{{instructions}}
{{else}}
{{instructions}}
{{/if}}
</{{name}}>
{{/if}}
{{/each}}

高级覆盖技术

1. 服务器指令转换

使用自定义逻辑转换指令:

markdown
{{#each servers}}
{{#if hasInstructions}}
<{{name}}>
{{#if (eq name "verbose-server")}}

# 简化的 {{name}} 指令

{{! 用简化版本替换冗长的指令 }}
此服务器提供文件操作。主要工具:

- read_file:读取文件内容
- write_file:写入文件内容
- list_files:列出目录内容
  {{else}}
  {{instructions}}
  {{/if}}
  </{{name}}>
  {{/if}}
  {{/each}}

2. 合并多个服务器

将多个服务器的指令合并到统一部分:

markdown
## 文件操作

{{#each servers}}
{{#if (or (eq name "filesystem") (eq name "storage"))}}
{{#if hasInstructions}}

### {{name}} 功能

{{instructions}}
{{/if}}
{{/if}}
{{/each}}

## 数据库操作

{{#each servers}}
{{#if (or (eq name "database") (eq name "sql"))}}
{{#if hasInstructions}}

### {{name}} 功能

{{instructions}}
{{/if}}
{{/if}}
{{/each}}

## 其他服务

{{#each servers}}
{{#unless (or (eq name "filesystem") (eq name "storage") (eq name "database") (eq name "sql"))}}
{{#if hasInstructions}}
<{{name}}>
{{instructions}}
</{{name}}>
{{/if}}
{{/unless}}
{{/each}}

3. 基于优先级的服务器排序

按重要性或偏好重新排序服务器:

markdown
## 高优先级服务器

{{#each servers}}
{{#if (or (eq name "critical-server") (eq name "primary-db"))}}
{{#if hasInstructions}}
<{{name}}>
🔥 **高优先级服务器**

{{instructions}}
</{{name}}>
{{/if}}
{{/if}}
{{/each}}

## 标准服务器

{{#each servers}}
{{#unless (or (eq name "critical-server") (eq name "primary-db"))}}
{{#if hasInstructions}}
<{{name}}>
{{instructions}}
</{{name}}>
{{/if}}
{{/unless}}
{{/each}}

用于服务器覆盖的 Handlebars 辅助函数

您可以使用这些内置的 Handlebars 辅助函数进行复杂逻辑:

辅助函数描述使用示例
eq相等比较{{#if (eq name "server1")}}
ne不等比较{{#if (ne name "server1")}}
or逻辑或{{#if (or (eq name "a") (eq name "b"))}}
and逻辑与{{#if (and hasInstructions (ne name "skip"))}}
startsWith字符串开头匹配{{#if (startsWith name "test-")}}
endsWith字符串结尾匹配{{#if (endsWith name "-dev")}}
contains字符串包含{{#if (contains instructions "deprecated")}}

实际覆盖示例

示例 1:特定环境指令

markdown
{{#each servers}}
{{#if hasInstructions}}
<{{name}}>
{{#if (endsWith name "-dev")}}

# 开发环境:{{name}}

⚠️ **开发模式**:此服务器仅用于开发。

{{instructions}}

**开发注意事项:**

- 调试已启用
- 所有操作都会详细记录
- 数据可能每天重置
  {{else if (endsWith name "-prod")}}

# 生产环境:{{name}}

**生产环境**:此服务器处理实时数据。

{{instructions}}

**生产准则:**

- 所有操作都会被审计
- 强制执行速率限制
- 遵循安全协议
  {{else}}
  {{instructions}}
  {{/if}}
  </{{name}}>
  {{/if}}
  {{/each}}

示例 2:服务器功能分组

markdown
# 按类别分类的服务器功能

## 数据存储和检索

{{#each servers}}
{{#if (or (contains name "db") (contains name "storage") (contains name "file"))}}
{{#if hasInstructions}}

### {{name}}

{{instructions}}
{{/if}}
{{/if}}
{{/each}}

## 通信和网络

{{#each servers}}
{{#if (or (contains name "web") (contains name "api") (contains name "http"))}}
{{#if hasInstructions}}

### {{name}}

{{instructions}}
{{/if}}
{{/if}}
{{/each}}

## 处理和计算

{{#each servers}}
{{#unless (or (contains name "db") (contains name "storage") (contains name "file") (contains name "web") (contains name "api") (contains name "http"))}}
{{#if hasInstructions}}

### {{name}}

{{instructions}}
{{/if}}
{{/unless}}
{{/each}}

测试您的模板覆盖

要测试您的模板覆盖并确保它们正常工作:

1. 创建测试模板

创建一个简单的测试模板来验证您的覆盖逻辑:

markdown
# 模板测试

{{#if hasServers}}
发现 {{serverCount}} 个带有指令的服务器。

{{#each servers}}
服务器:{{name}}(有指令:{{hasInstructions}})
{{#if hasInstructions}}
指令长度:{{instructions.length}} 字符
{{/if}}

{{/each}}
{{else}}
未找到服务器。
{{/if}}

2. 使用 CLI 测试

将您的模板保存到文件并测试:

bash
# 创建测试模板
echo "{{#each servers}}{{name}}: {{hasInstructions}}{{/each}}" > test-template.md

# 使用您的模板测试
1mcp serve --instructions-template test-template.md

# 连接客户端查看渲染输出

3. 验证步骤

  1. 语法检查:确保 Handlebars 语法有效
  2. 逻辑验证:使用不同的服务器配置测试条件逻辑
  3. 边缘情况:测试无服务器、单个服务器、没有指令的服务器
  4. 性能:监控多个服务器时的渲染时间

4. 常见测试场景

针对这些常见场景测试您的模板:

  • 无服务器连接:模板应优雅地处理空状态
  • 混合服务器类型:一些有指令,一些没有
  • 长指令:确保格式保持可读
  • 特殊字符:测试包含特殊字符的服务器名称
  • 多种环境:测试 dev/staging/prod 服务器命名模式

服务器指令覆盖技巧

  1. 测试您的逻辑:先使用简单条件,然后构建复杂性
  2. 保留原始内容:考虑保持原始指令可用并进行修改
  3. 使用注释:Handlebars 注释 {{! comment }} 有助于记录您的逻辑
  4. 验证服务器名称:检查服务器名称是否符合您期望的模式
  5. 处理边缘情况:考虑没有指令或意外名称的服务器
  6. 性能:模板中的复杂逻辑在服务器数量多时可能减慢渲染速度
  7. 文档:为团队成员记录您的覆盖逻辑
  8. 版本控制:将模板保存在版本控制中以跟踪更改

模板问题排查

常见问题和解决方案

  1. 模板未加载:检查文件路径和权限
  2. 语法错误:使用验证器验证 Handlebars 语法
  3. 逻辑不工作:逐步测试各个条件
  4. 性能问题:简化复杂的嵌套循环
  5. 输出格式:检查额外的空白或缺少的换行符

调试模板变量

使用此调试模板检查可用变量:

markdown
# 调试模板

## 可用变量

- serverCount: {{serverCount}}
- hasServers: {{hasServers}}
- serverList: {{serverList}}
- toolPattern: {{toolPattern}}
- title: {{title}}

## 服务器详情

{{#each servers}}

### 服务器 {{@index}}:{{name}}

- 有指令:{{hasInstructions}}
- 指令长度:{{instructions.length}}
  {{#if hasInstructions}}
- 前 100 个字符:{{substring instructions 0 100}}...
  {{/if}}

{{/each}}

此模板将帮助您了解哪些数据可用以及它们的结构。

基于 Apache 2.0 许可发布