scaffold-mcp-server
정보
이 Claude Skill은 템플릿을 사용하여 새로운 Model Context Protocol (MCP) 서버의 완전한 프로젝트 구조를 생성합니다. TypeScript, Python 또는 R을 위한 프로젝트 설정, 도구 정의, 전송 처리 및 테스트를 구성합니다. 새로운 MCP 서버 프로젝트를 빠르게 시작하고, 일관된 기반을 보장하며, 초기 개발 속도를 높이는 데 사용하세요.
빠른 설치
Claude Code
추천npx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/scaffold-mcp-serverClaude Code에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요
문서
name: scaffold-mcp-server locale: es source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16 description: > Generar la estructura de un nuevo servidor MCP desde plantillas, incluyendo configuración del proyecto, definición de herramientas, manejo de transporte, y configuración de testing. Soportar TypeScript, Python y R como lenguajes de implementación. Usar cuando se inicie un nuevo proyecto de servidor MCP, se necesite una estructura consistente, o se quiera acelerar el desarrollo inicial. license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: mcp-integration complexity: intermediate language: multi tags: mcp, scaffold, template, server, project-structure
Crear Andamiaje de Servidor MCP
Generar la estructura de un nuevo proyecto de servidor MCP desde plantillas.
Cuándo Usar
- Iniciando un nuevo proyecto de servidor MCP
- Necesitando una estructura de proyecto consistente y probada
- Acelerando el desarrollo inicial con plantillas pre-configuradas
- Estandarizando la creación de servidores MCP en un equipo
- Prototipando rápidamente integraciones MCP
Entradas
- Requerido: Nombre del servidor MCP
- Requerido: Lenguaje de implementación (TypeScript, Python, R)
- Requerido: Lista de herramientas a implementar
- Opcional: Tipo de transporte (stdio, HTTP/SSE)
- Opcional: Servicios externos a integrar
- Opcional: Requisitos de autenticación
Procedimiento
Paso 1: Crear Estructura del Proyecto (TypeScript)
mkdir mi-mcp-server && cd mi-mcp-server
# Inicializar proyecto
npm init -y
npm install @modelcontextprotocol/sdk zod
npm install -D typescript @types/node tsx vitest
# Configurar TypeScript
npx tsc --init --outDir dist --rootDir src --strict true \
--module nodenext --moduleResolution nodenext --target es2022
Estructura generada:
mi-mcp-server/
├── src/
│ ├── index.ts # Punto de entrada
│ ├── server.ts # Configuración del servidor
│ ├── tools/ # Definiciones de herramientas
│ │ ├── index.ts
│ │ └── ejemplo.ts
│ ├── resources/ # Definiciones de recursos
│ │ └── index.ts
│ └── utils/ # Utilidades compartidas
│ └── logger.ts
├── tests/
│ └── tools.test.ts
├── package.json
├── tsconfig.json
└── README.md
Esperado: Estructura del proyecto creada con todas las dependencias instaladas.
En caso de fallo: Verificar versión de Node.js (18+), comprobar acceso a npm.
Paso 2: Implementar Servidor Base
// src/server.ts
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
import { registrarHerramientas } from "./tools/index.js";
import { registrarRecursos } from "./resources/index.js";
export async function iniciarServidor() {
const server = new McpServer({
name: "mi-mcp-server",
version: "1.0.0",
});
// Registrar herramientas y recursos
registrarHerramientas(server);
registrarRecursos(server);
// Conectar transporte
const transport = new StdioServerTransport();
await server.connect(transport);
console.error("Servidor MCP iniciado exitosamente");
}
// src/index.ts
import { iniciarServidor } from "./server.js";
iniciarServidor().catch(console.error);
Esperado: Servidor base que inicia y acepta conexiones MCP.
En caso de fallo: Verificar importaciones de módulos, comprobar configuración de TypeScript.
Paso 3: Definir Herramientas con Plantilla
// src/tools/ejemplo.ts
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { z } from "zod";
export function registrarHerramientaEjemplo(server: McpServer) {
server.tool(
"ejemplo-saludo",
"Genera un saludo personalizado",
{
nombre: z.string().describe("Nombre de la persona a saludar"),
idioma: z.enum(["es", "en", "de"]).optional().default("es")
.describe("Idioma del saludo"),
},
async ({ nombre, idioma }) => {
const saludos: Record<string, string> = {
es: `¡Hola, ${nombre}!`,
en: `Hello, ${nombre}!`,
de: `Hallo, ${nombre}!`,
};
return {
content: [{
type: "text",
text: saludos[idioma] ?? saludos.es,
}],
};
}
);
}
// src/tools/index.ts
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { registrarHerramientaEjemplo } from "./ejemplo.js";
export function registrarHerramientas(server: McpServer) {
registrarHerramientaEjemplo(server);
// Agregar más herramientas aquí
}
Esperado: Herramientas definidas con esquemas claros, descripciones, y manejo de errores.
En caso de fallo: Verificar que los esquemas zod son válidos, comprobar que las descripciones son informativas.
Paso 4: Configurar Scripts y Testing
// package.json (scripts)
{
"scripts": {
"build": "tsc",
"start": "node dist/index.js",
"dev": "tsx src/index.ts",
"test": "vitest",
"lint": "tsc --noEmit"
}
}
// tests/tools.test.ts
import { describe, it, expect } from "vitest";
describe("Herramienta ejemplo-saludo", () => {
it("genera saludo en español por defecto", async () => {
// Implementar test de integración
});
});
# Compilar y probar
npm run build
npm run start
# Agregar a Claude Code
claude mcp add mi-mcp-server stdio node -- dist/index.js
Esperado: El servidor se compila, pruebas pasan, y se registra exitosamente en Claude Code.
En caso de fallo: Revisar errores de compilación de TypeScript, verificar paths de importación.
Paso 5: Crear Estructura Python (Alternativa)
mkdir mi-mcp-server && cd mi-mcp-server
python -m venv venv
source venv/bin/activate
pip install mcp pydantic pytest
# src/server.py
from mcp.server import Server
from mcp.server.stdio import stdio_server
from mcp.types import Tool, TextContent
import json
app = Server("mi-mcp-server")
@app.tool()
async def ejemplo_saludo(nombre: str, idioma: str = "es") -> list[TextContent]:
"""Genera un saludo personalizado."""
saludos = {"es": f"¡Hola, {nombre}!", "en": f"Hello, {nombre}!"}
return [TextContent(type="text", text=saludos.get(idioma, saludos["es"]))]
async def main():
async with stdio_server() as (read_stream, write_stream):
await app.run(read_stream, write_stream)
if __name__ == "__main__":
import asyncio
asyncio.run(main())
Esperado: Servidor Python funcionando con herramientas registradas.
En caso de fallo: Verificar versión de Python (3.10+), comprobar instalación de dependencias.
Validación
- La estructura del proyecto sigue las convenciones del lenguaje
- El servidor compila/ejecuta sin errores
- Las herramientas están registradas y son accesibles
- Los tests están configurados y ejecutan
- El servidor se puede agregar a Claude Code exitosamente
- La documentación del proyecto está incluida (README)
Errores Comunes
- Estructura desorganizada: Separar herramientas, recursos, y utilidades en directorios distintos.
- Sin validación de entrada: Siempre usar zod (TS) o pydantic (Python) para validar parámetros.
- Sin manejo de errores global: Envolver el punto de entrada en try/catch para errores fatales.
- Descripción de herramientas faltante: Cada herramienta necesita una descripción clara para que el modelo sepa cuándo usarla.
- No documentar la instalación: Incluir instrucciones claras de setup en el README.
Habilidades Relacionadas
build-custom-mcp-server- Implementación detallada de servidores MCPconfigure-mcp-server- Configurar el servidor en clientes MCPanalyze-codebase-for-mcp- Analizar código para decidir qué exponercontainerize-mcp-server- Contenerizar el servidor MCP resultante
GitHub 저장소
연관 스킬
evaluating-llms-harness
테스팅이 Claude Skill은 MMLU, GSM8K를 포함한 60개 이상의 표준화된 학술 과제에서 LLM 성능을 벤치마크하기 위해 lm-evaluation-harness를 실행합니다. 개발자들이 모델 품질을 비교하고, 학습 진행 상황을 추적하거나 학술 결과를 보고할 수 있도록 설계되었습니다. 이 도구는 HuggingFace와 vLLM 모델을 포함한 다양한 백엔드를 지원합니다.
cloudflare-cron-triggers
테스팅이 스킬은 cron 표현식을 사용하여 Worker를 스케줄링하기 위한 Cloudflare Cron Triggers 구현에 관한 포괄적인 지식을 제공합니다. 주기적 작업, 유지보수 작업, 자동화된 워크플로우 설정 방법을 다루며, 잘못된 cron 표현식이나 시간대 문제 같은 일반적인 이슈들을 해결하는 방법을 포함합니다. 개발자들은 이를 통해 스케줄된 핸들러 구성, cron 트리거 테스트, Workflows 및 Green Compute와의 연동 작업을 수행할 수 있습니다.
webapp-testing
테스팅이 Claude Skill은 Python 스크립트를 통해 로컬 웹 애플리케이션을 테스트하기 위한 Playwright 기반 툴킷을 제공합니다. 프론트엔드 검증, UI 디버깅, 스크린샷 캡처, 로그 확인 기능을 지원하며 서버 라이프사이클을 관리합니다. 브라우저 자동화 작업에 사용하되 컨텍스트 오염을 방지하기 위해 소스 코드를 읽지 않고 스크립트를 직접 실행하세요.
finishing-a-development-branch
테스팅이 스킬은 테스트 통과를 확인한 후 체계적인 통합 옵션을 제시하여 개발자가 완성된 작업을 마무리하도록 돕습니다. 구현이 완료된 후 머지, PR 생성, 브랜치 정리와 같은 워크플로우를 안내합니다. 코드가 준비되고 테스트가 완료되었을 때 개발 프로세스를 체계적으로 마무리하기 위해 사용하세요.
