scaffold-mcp-server
정보
이 스킬은 공식 TypeScript 또는 Python SDK를 사용하여 도구 명세로부터 완전한 MCP 서버 프로젝트를 생성합니다. 적절한 서버 구조를 위해 전송 구성, 도구 핸들러 및 테스트 하네스를 만듭니다. 새로운 MCP 서버를 시작하거나, 기존 도구를 MCP로 이전하거나, Claude Code로 테스트하기 위한 도구 표면을 프로토타이핑할 때 사용하세요.
빠른 설치
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에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요
문서
搭 MCP 服務
依工具之規,用官 MCP SDK(TypeScript 或 Python),生完備可行之 MCP 服務項目。
用時
- 已有工具之規(自
analyze-codebase-for-mcp或人手書),需可行之服乃用 - 新立 MCP 服項目,欲自始得正之結構乃用
- 既有工具之集遷至 MCP 協乃用
- 全施前以 Claude Code 試工具之面乃用
- 需服之搭與 CI 之試套乃用
入
- 必要:工具規之文(YAML 或 JSON,含工具名、參、返之類)
- 必要:目標之語(
typescript或python) - 必要:傳輸之類(
stdio或sse) - 可選:出之目(默:當前目)
- 可選:包之名與版
- 可選:認證之法(
none、bearer-token、api-key) - 可選:Docker 之裝(
true或false,默:false)
法
第一步:擇 SDK 之語與傳輸
1.1. 依項目之境擇施之語:
- TypeScript:宜於 Node.js 之生態、近 web 之器、JSON 重之為
- Python:宜於數據科學、ML、科學計算之工具面
1.2. 擇傳輸之機:
- stdio:本地工具行之默。Claude Code 起服為子程
- SSE(Server-Sent Events):為遠/共服。需 HTTP 之宿
1.3. 定認證之求:
- none:本地 stdio 服(程級之信)
- bearer-token:遠 SSE 服附靜令
- api-key:遠服每客之鑰
得:語、傳輸、認證之擇皆書。
敗則:求曖昧,默用 TypeScript + stdio + 無認證以最速得行之服。
第二步:始項目之結構
2.1. 建項目目而始:
TypeScript:
mkdir -p $PROJECT_NAME && cd $PROJECT_NAME
npm init -y
npm install @modelcontextprotocol/sdk zod
npm install -D typescript @types/node tsx
npx tsc --init --target ES2022 --module nodenext --moduleResolution nodenext --outDir dist
Python:
mkdir -p $PROJECT_NAME && cd $PROJECT_NAME
python -m venv .venv
source .venv/bin/activate
pip install mcp pydantic
2.2. 立標準目之結構:
$PROJECT_NAME/
├── src/
│ ├── index.ts|main.py # Server entry point
│ ├── tools/ # One file per tool category
│ │ ├── index.ts|__init__.py
│ │ └── [category].ts|.py
│ └── utils/ # Shared utilities
│ └── validation.ts|.py
├── test/
│ ├── harness.ts|.py # MCP test harness
│ └── tools/
│ └── [category].test.ts|.py
├── package.json|pyproject.toml
├── tsconfig.json # TypeScript only
├── Dockerfile # If Docker requested
└── README.md
2.3. 增 npm 之 bin 條(TypeScript)或 Python 之入點:
TypeScript package.json:
{
"name": "$PACKAGE_NAME",
"version": "1.0.0",
"type": "module",
"bin": { "$PACKAGE_NAME": "./dist/index.js" },
"scripts": {
"build": "tsc",
"start": "node dist/index.js",
"dev": "tsx src/index.ts",
"test": "tsx test/harness.ts"
}
}
得:可建之項目骨,諸依皆裝。
敗則:npm/pip 裝敗,察網與註冊之訪。TypeScript 須 Node.js >= 18。Python 須 Python >= 3.10。
第三步:依規施工具之手
3.1. 析工具規之文,每工具生一手:
TypeScript 之手模:
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { z } from "zod";
export function registerTools(server: McpServer): void {
server.tool(
"tool_name",
"Tool description from spec",
{
param1: z.string().describe("Parameter description"),
param2: z.number().optional().default(10).describe("Optional param"),
},
async ({ param1, param2 }) => {
try {
// TODO: Implement tool logic
const result = await performAction(param1, param2);
return {
content: [{ type: "text", text: JSON.stringify(result, null, 2) }],
};
} catch (error) {
return {
content: [{ type: "text", text: `Error: ${(error as Error).message}` }],
isError: true,
};
}
}
);
}
Python 之手模:
from mcp.server import Server
from mcp.types import Tool, TextContent
from pydantic import BaseModel
class ToolNameParams(BaseModel):
param1: str
param2: int = 10
async def handle_tool_name(params: ToolNameParams) -> list[TextContent]:
try:
result = await perform_action(params.param1, params.param2)
return [TextContent(type="text", text=json.dumps(result, indent=2))]
except Exception as e:
return [TextContent(type="text", text=f"Error: {e}")]
3.2. 依規生每類一手文件。
3.3. 增類察之外之入驗:
- 串長之限
- 數範之界
- 枚值之約
- 必域之強
3.4. 增結構之誤應於諸預期之敗模。
得:每類一手文件,附類參與誤處。
敗則:規含曖昧之類,默為 string 並加 TODO 之注以待人手細之。
第四步:配傳輸
4.1. 立服之入點,附所擇之傳輸:
stdio(TypeScript):
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
import { registerTools } from "./tools/index.js";
const server = new McpServer({
name: "$PACKAGE_NAME",
version: "1.0.0",
});
registerTools(server);
const transport = new StdioServerTransport();
await server.connect(transport);
SSE(TypeScript):
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { SSEServerTransport } from "@modelcontextprotocol/sdk/server/sse.js";
import { registerTools } from "./tools/index.js";
const server = new McpServer({
name: "$PACKAGE_NAME",
version: "1.0.0",
});
registerTools(server);
const transport = new SSEServerTransport("/messages", response);
await server.connect(transport);
4.2. 若需認證,增中間件:
- Bearer 令:驗
Authorization頭 - API 鑰:驗
X-API-Key頭
4.3. stdio 服增 shebang 線,使可直行:
#!/usr/bin/env node
得:行之入點,於所配傳輸啟 MCP 服。
敗則:SDK 版與引徑不合,察 @modelcontextprotocol/sdk 之版而調引。SDK 諸版間重構其徑。
第五步:建試套
5.1. 立試套以驗每工具:
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { InMemoryTransport } from "@modelcontextprotocol/sdk/inMemory.js";
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
async function runTests(): Promise<void> {
const server = createServer();
const [clientTransport, serverTransport] = InMemoryTransport.createLinkedPair();
await server.connect(serverTransport);
const client = new Client({ name: "test-client", version: "1.0.0" });
await client.connect(clientTransport);
// Test: tools/list returns all expected tools
const tools = await client.listTools();
console.assert(tools.tools.length === EXPECTED_TOOL_COUNT);
// Test: each tool with valid input
for (const tool of tools.tools) {
const result = await client.callTool({
name: tool.name,
arguments: getTestInput(tool.name),
});
console.assert(!result.isError, `${tool.name} failed`);
}
// Test: each tool with invalid input returns isError
for (const tool of tools.tools) {
const result = await client.callTool({
name: tool.name,
arguments: getInvalidInput(tool.name),
});
console.assert(result.isError, `${tool.name} should reject invalid input`);
}
console.log("All tests passed");
}
5.2. 為每工具立試裝:有效之入、無效之入、邊例。
5.3. 增 test 本於 package.json 或 pyproject.toml。
得:試套以有效與無效之入皆練每工具。
敗則:SDK 版無 InMemoryTransport,退為起服為子程而以 stdio 管通。
第六步:生文檔與配置
6.1. 生 README.md,含:
- 項目之述
- 裝之令
- Claude Code 之配令
- Claude Desktop JSON 之配片
- 工具列含述與參之模
- 開發與試之令
6.2. 生 Claude Code 之註命:
# stdio transport
claude mcp add $PACKAGE_NAME stdio "node" "dist/index.js"
# SSE transport
claude mcp add $PACKAGE_NAME -e API_KEY=your_key -- mcp-remote http://localhost:3000/mcp
6.3. 生 Claude Desktop 之配片:
{
"mcpServers": {
"$PACKAGE_NAME": {
"command": "node",
"args": ["path/to/dist/index.js"]
}
}
}
6.4. 若求 Docker,生 Dockerfile:
FROM node:20-slim AS build
WORKDIR /app
COPY package*.json ./
RUN npm ci
COPY . .
RUN npm run build
FROM node:20-slim
WORKDIR /app
COPY --from=build /app/dist ./dist
COPY --from=build /app/node_modules ./node_modules
COPY --from=build /app/package.json .
ENTRYPOINT ["node", "dist/index.js"]
得:完備之文檔與配文件,可即用。
敗則:所生 README 含占位,於項目搜實值以代。Docker 建敗,驗基像合所用之 Node.js/Python 版。
驗
- 項目建無誤(
npm run build或等者) - 服啟而應
tools/listJSON-RPC 之請 - 規之每工具皆註且可察
- 試套以有效之入皆過
- 試套確無效之入返誤
- Claude Code 可以
claude mcp add連 - README 含可行之裝與配令
- 諸所生之碼皆過 lint(若已配)
陷
- SDK 引徑之變:
@modelcontextprotocol/sdk諸版間重構其出。常察所裝版之實出徑 - 忘 shebang:直呼之 stdio 服需
#!/usr/bin/env node為首線方可行 - 阻事件循環:TypeScript 之手必為
async。同步操阻服上諸他工具呼 - package.json 缺
type: "module":MCP SDK 用 ESM 引。無"type": "module",Node.js 視文件為 CommonJS 而引敗 - Zod 模之漂:規進而 Zod 模未更,驗不合致默敗。自單一真源生模
- stdout 之污:stdio 傳用 stdout 為 JSON-RPC。手中之
console.log污協流。用console.error或文件日誌代之
參
analyze-codebase-for-mcp— 生此技所用之工具規build-custom-mcp-server— 繁例之手施configure-mcp-server— 連所搭之服於 Claude Code/Desktoptroubleshoot-mcp-connection— 展後察連之患containerize-mcp-server— 以 Docker 裝服以散布
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 생성, 브랜치 정리와 같은 워크플로우를 안내합니다. 코드가 준비되고 테스트가 완료되었을 때 개발 프로세스를 체계적으로 마무리하기 위해 사용하세요.
