MCP HubMCP Hub
스킬 목록으로 돌아가기

scaffold-mcp-server

pjt222
업데이트됨 6 days ago
19 조회
17
2
17
GitHub에서 보기
테스팅aitestingmcp

정보

이 스킬은 공식 TypeScript 또는 Python SDK를 사용하여 도구 명세로부터 완전한 MCP 서버를 구성합니다. 전송 설정, 도구 핸들러, 테스트 하네스를 생성하여 처음부터 올바른 프로젝트 구조를 제공합니다. 새로운 MCP 서버를 시작하거나 기존 통합을 이전하거나 Claude Code로 테스트하기 위한 도구 인터페이스를 프로토타이핑할 때 사용하세요.

빠른 설치

Claude Code

추천
기본
npx skills add pjt222/agent-almanac -a claude-code
플러그인 명령대체
/plugin add https://github.com/pjt222/agent-almanac
Git 클론대체
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/scaffold-mcp-server

Claude Code에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요

문서

架 MCP 服

從工譜生完備可行 MCP 服項,用官 MCP SDK(TypeScript 或 Python)。

  • 有工譜需可行服→用
  • 始新 MCP 服項欲始即正→用
  • 遷既工接於 MCP→用
  • 原型工面預測 Claude Code→用
  • 需服架與 CI 測台→用

  • :工譜文(YAML 或 JSON 含名、參、返)
  • :標語(typescriptpython
  • :傳型(stdiosse
  • :出目(默:當)
  • :包名與本
  • :認法(nonebearer-tokenapi-key
  • :Docker 包(true/false,默 false

一:選 SDK 語與傳

1.1. 按項境擇行語:

  • TypeScript:宜 Node.js 生、近網、JSON 重
  • Python:宜資科、ML、科算

1.2. 擇傳:

  • stdio:默為地行。Claude Code 啟服為子進程
  • SSE:遠/共服。需 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
│   ├── tools/
│   │   ├── index.ts|__init__.py
│   │   └── [category].ts|.py
│   └── utils/
│       └── validation.ts|.py
├── test/
│   ├── harness.ts|.py
│   └── tools/
│       └── [category].test.ts|.py
├── package.json|pyproject.toml
├── tsconfig.json
├── Dockerfile
└── 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 需 ≥ 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 {
        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 key:驗 X-API-Key

4.3. stdio 服加首行以可執:

#!/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);

  const tools = await client.listTools();
  console.assert(tools.tools.length === EXPECTED_TOOL_COUNT);

  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`);
  }

  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.jsonpyproject.toml

得:測台行諸工於有效與無效入。

敗:InMemoryTransport SDK 本無→退至子進程啟服經 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/list JSON-RPC
  • 譜諸工皆註可發
  • 測台過諸工於有效入
  • 測台確誤應於無效入
  • Claude Code 經 claude mcp add 可連
  • README 含可行裝配令
  • 生碼過 lint(如配)

  • SDK 入路改@modelcontextprotocol/sdk 本間重組出。必查裝本實出路
  • 忘 shebang:直行 stdio 服需首行 #!/usr/bin/env node
  • 阻事循:TypeScript 工處需 async。同步操阻服諸工
  • type: "module":MCP SDK 用 ESM 入。缺則 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
  • troubleshoot-mcp-connection
  • containerize-mcp-server

GitHub 저장소

pjt222/agent-almanac
경로: i18n/wenyan-ultra/skills/scaffold-mcp-server
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

연관 스킬

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 생성, 브랜치 정리와 같은 워크플로우를 안내합니다. 코드가 준비되고 테스트가 완료되었을 때 개발 프로세스를 체계적으로 마무리하기 위해 사용하세요.

스킬 보기