MCP로 할 수 있는 것
MCP 서버가 연결되면 Claude Code에 다음을 요청할 수 있습니다:- 이슈 추적기에서 기능 구현: “JIRA 이슈 ENG-4521에 설명된 기능을 추가하고 GitHub에서 PR을 생성하세요.”
- 모니터링 데이터 분석: “Sentry와 Statsig을 확인하여 ENG-4521에 설명된 기능의 사용량을 확인하세요.”
- 데이터베이스 쿼리: “PostgreSQL 데이터베이스를 기반으로 기능 ENG-4521을 사용한 무작위 사용자 10명의 이메일을 찾으세요.”
- 디자인 통합: “Slack에 게시된 새로운 Figma 디자인을 기반으로 표준 이메일 템플릿을 업데이트하세요.”
- 워크플로우 자동화: “이 10명의 사용자를 새로운 기능에 대한 피드백 세션에 초대하는 Gmail 초안을 생성하세요.”
- 외부 이벤트에 반응: MCP 서버는 채널로도 작동할 수 있으며, 세션에 메시지를 푸시하므로 Claude는 자리를 비운 동안 Telegram 메시지, Discord 채팅 또는 webhook 이벤트에 반응할 수 있습니다.
MCP 서버 찾기 및 구축
Anthropic Directory에서 검토된 커넥터를 찾아보세요. Directory 커넥터는 Claude Code와 동일한 MCP 인프라를 사용하므로claude mcp add를 사용하여 여기에 나열된 모든 원격 서버를 추가할 수 있습니다.
자신만의 서버를 구축하려면 프로토콜 기본 사항에 대한 MCP 서버 가이드와 인증, 테스트 및 Directory 제출에 대한 Claude 커넥터 구축 문서를 참조하세요.
공식 mcp-server-dev 플러그인을 사용하여 Claude가 서버를 스캐폴드하도록 할 수도 있습니다.
플러그인 설치
Claude Code 세션에서 다음을 실행하세요:Claude Code가 마켓플레이스를 찾을 수 없다고 보고하면 먼저
/plugin marketplace add anthropics/claude-plugins-official을 실행한 다음 설치를 다시 시도하세요. 설치가 완료되면 /reload-plugins를 실행하여 현재 세션에서 활성화하세요.MCP 서버 설치
MCP 서버는 필요에 따라 여러 가지 방식으로 구성할 수 있습니다:옵션 1: 원격 HTTP 서버 추가
HTTP 서버는 원격 MCP 서버에 연결하기 위한 권장 옵션입니다. 이는 클라우드 기반 서비스에 가장 널리 지원되는 전송 방식입니다..mcp.json, ~/.claude.json 또는 claude mcp add-json을 통해 JSON으로 MCP 서버를 구성할 때, type 필드는 http의 별칭으로 streamable-http를 허용합니다. MCP 사양은 이 전송에 대해 streamable-http라는 이름을 사용하므로 서버 설명서에서 복사한 구성이 수정 없이 작동합니다.
옵션 2: 원격 SSE 서버 추가
옵션 3: 로컬 stdio 서버 추가
Stdio 서버는 컴퓨터에서 로컬 프로세스로 실행됩니다. 시스템에 직접 액세스하거나 사용자 정의 스크립트가 필요한 도구에 이상적입니다. Claude Code는 생성된 서버의 환경에서CLAUDE_PROJECT_DIR을 프로젝트 루트로 설정하므로 서버는 작업 디렉터리에 의존하지 않고 프로젝트 상대 경로를 확인할 수 있습니다. 이는 hooks가 CLAUDE_PROJECT_DIR 변수에서 받는 것과 동일한 디렉터리입니다. 서버 프로세스 내에서 읽으세요. 예를 들어 Node에서는 process.env.CLAUDE_PROJECT_DIR 또는 Python에서는 os.environ["CLAUDE_PROJECT_DIR"]입니다. 서버는 또한 MCP roots/list 요청을 호출할 수 있으며, 이는 Claude Code가 시작된 디렉터리를 반환합니다.
이 변수는 Claude Code 자체의 환경이 아닌 서버의 환경에 설정되므로 프로젝트 또는 사용자 범위의 .mcp.json command 또는 args에서 ${VAR} 확장을 통해 참조하려면 ${CLAUDE_PROJECT_DIR:-.}와 같은 기본값이 필요합니다. 플러그인 제공 MCP 구성은 ${CLAUDE_PROJECT_DIR}을 직접 대체하며 기본값이 필요하지 않습니다.
중요: 옵션 순서모든 옵션(
--transport, --env, --scope, --header)은 서버 이름 앞에 와야 합니다. -- (이중 대시)는 서버 이름과 MCP 서버에 전달되는 명령 및 인수를 구분합니다.예를 들어:claude mcp add --transport stdio myserver -- npx server→npx server실행claude mcp add --transport stdio --env KEY=value myserver -- python server.py --port 8080→KEY=value를 환경에서python server.py --port 8080실행
옵션 4: 원격 WebSocket 서버 추가
WebSocket 서버는 지속적인 양방향 연결을 유지하므로 Claude에 예고 없이 이벤트를 푸시하는 원격 MCP 서버에 적합합니다. 서버가 요청에만 응답하는 경우 HTTP를 대신 사용하세요. HTTP는 OAuth 및claude mcp add --transport 플래그를 지원하지만 WebSocket은 둘 다 지원하지 않습니다.
.mcp.json 또는 claude mcp add-json으로 WebSocket 서버를 구성하세요:
type: "ws" 항목은 http와 동일한 url, headers, headersHelper, timeout 및 alwaysLoad 필드를 허용합니다. 인증은 헤더 전용이므로 headers에 정적 토큰을 전달하거나 headersHelper를 사용하여 연결 시 토큰을 생성하세요. claude mcp add --transport 플래그는 ws를 허용하지 않습니다.
서버 관리
구성한 후에는 다음 명령으로 MCP 서버를 관리할 수 있습니다:.mcp.json의 프로젝트 범위 서버 중 승인을 기다리는 서버는 claude mcp list에 ⏸ 승인 대기 중으로 나타납니다. claude를 대화형으로 실행하여 검토하고 승인하세요. claude mcp get <name>은 보류 중인 서버를 ⏸ 승인 대기 중으로 표시하고 거부된 서버를 ✗ 거부됨으로 표시합니다.
/mcp 패널은 각 연결된 서버 옆에 도구 개수를 표시하고 도구 기능을 광고하지만 도구를 노출하지 않는 서버에 플래그를 지정합니다.
요청이 백그라운드에서 아직 연결 중인 서버의 도구가 필요한 경우 Claude는 해당 서버가 연결될 때까지 기다립니다. 도구 검색이 활성화되어 있으면 (기본값), 대기는 ToolSearch 호출 내에서 발생합니다. Vertex AI, 사용자 정의 ANTHROPIC_BASE_URL 또는 ENABLE_TOOL_SEARCH=false와 같이 도구 검색이 없는 구성에서는 Claude가 대신 WaitForMcpServers 도구를 사용합니다.
서버 이름 workspace는 내부 사용을 위해 예약되어 있습니다. 구성에서 해당 이름의 서버를 정의하면 Claude Code는 로드 시 이를 건너뛰고 이름을 바꾸도록 요청하는 경고를 표시합니다.
동적 도구 업데이트
Claude Code는 MCPlist_changed 알림을 지원하므로 MCP 서버가 연결을 끊었다가 다시 연결할 필요 없이 사용 가능한 도구, 프롬프트 및 리소스를 동적으로 업데이트할 수 있습니다. MCP 서버가 list_changed 알림을 보내면 Claude Code는 해당 서버에서 사용 가능한 기능을 자동으로 새로 고칩니다.
자동 재연결
HTTP 또는 SSE 서버가 세션 중에 연결이 끊어지면 Claude Code는 지수 백오프를 사용하여 자동으로 재연결합니다: 최대 5번의 시도, 1초 지연으로 시작하여 매번 두 배씩 증가합니다. 서버는 재연결이 진행 중인 동안/mcp에서 보류 중으로 나타납니다. 5번의 실패 시도 후 서버는 실패로 표시되며 /mcp에서 수동으로 다시 시도할 수 있습니다. Stdio 서버는 로컬 프로세스이며 자동으로 재연결되지 않습니다.
HTTP 또는 SSE 서버가 시작 시 초기 연결에 실패할 때도 동일한 백오프가 적용됩니다. v2.1.121부터 Claude Code는 5xx 응답, 연결 거부 또는 시간 초과와 같은 일시적 오류에 대해 초기 연결을 최대 3번 재시도한 후, 여전히 연결할 수 없으면 서버를 실패로 표시합니다. 인증 및 찾을 수 없음 오류는 해결하기 위해 구성 변경이 필요하므로 재시도되지 않습니다.
채널을 사용한 메시지 푸시
MCP 서버는 또한 메시지를 세션에 직접 푸시할 수 있으므로 Claude는 CI 결과, 모니터링 경고 또는 채팅 메시지와 같은 외부 이벤트에 반응할 수 있습니다. 이를 활성화하려면 서버가claude/channel 기능을 선언하고 시작 시 --channels 플래그로 옵트인합니다. 공식적으로 지원되는 채널을 사용하려면 채널을 참조하거나, 자신만의 채널을 구축하려면 채널 참조를 참조하세요.
서버당 timeout은 도구 호출당 하드 월클록 제한이며, 서버의 진행 알림은 이를 연장하지 않습니다. 1000 미만의 값은 1초로 내림됩니다. HTTP 및 SSE 서버의 경우, 요청당 fetch 첫 바이트 예산은 이 값에 관계없이 최소 60초이므로 도구 호출 감시견만 더 작은 값을 준수합니다.
플러그인 제공 MCP 서버
플러그인은 MCP 서버를 번들로 제공할 수 있으며, 플러그인이 활성화되면 도구 및 통합을 자동으로 제공합니다. 플러그인 MCP 서버는 사용자 구성 서버와 동일하게 작동합니다. 플러그인 MCP 서버의 작동 방식:- 플러그인은 플러그인 루트의
.mcp.json또는plugin.json에 인라인으로 MCP 서버를 정의합니다 - 플러그인이 활성화되면 MCP 서버가 자동으로 시작됩니다
- 플러그인 MCP 도구는 수동으로 구성된 MCP 도구와 함께 나타납니다
- 플러그인 서버는 플러그인 설치를 통해 관리됩니다 (
/mcp명령이 아님)
.mcp.json:
plugin.json에 인라인:
- 자동 라이프사이클: 세션 시작 시 활성화된 플러그인의 서버가 자동으로 연결됩니다. 세션 중에 플러그인을 활성화하거나 비활성화하면
/reload-plugins를 실행하여 MCP 서버를 연결하거나 연결 해제합니다 - 환경 변수: 번들된 플러그인 파일에
${CLAUDE_PLUGIN_ROOT}사용, 플러그인 업데이트를 유지하는 지속적인 상태에${CLAUDE_PLUGIN_DATA}사용, 그리고 안정적인 프로젝트 루트에${CLAUDE_PROJECT_DIR}사용 - 사용자 환경 액세스: 수동으로 구성된 서버와 동일한 환경 변수에 액세스
- 여러 전송 유형: stdio, SSE, HTTP 및 WebSocket 전송 지원 (전송 지원은 서버에 따라 다를 수 있음)
- 번들 배포: 도구 및 서버가 함께 패키징됨
- 자동 설정: 수동 MCP 구성이 필요 없음
- 팀 일관성: 플러그인이 설치되면 모든 사람이 동일한 도구를 얻음
MCP 설치 범위
MCP 서버는 세 가지 범위에서 구성할 수 있습니다. 선택한 범위는 서버가 로드되는 프로젝트와 구성이 팀과 공유되는지 여부를 제어합니다. 관리자는 관리형 구성을 통해 엔터프라이즈 수준에서 서버를 배포할 수도 있습니다.로컬 범위
로컬 범위는 기본값입니다. 로컬 범위 서버는 추가한 프로젝트에서만 로드되며 사용자에게만 비공개입니다. Claude Code는 해당 프로젝트의 경로 아래~/.claude.json에 저장하므로 다른 프로젝트에는 동일한 서버가 나타나지 않습니다. 개인 개발 서버, 실험적 구성 또는 버전 제어에 포함하고 싶지 않은 자격 증명이 있는 서버에 로컬 범위를 사용하세요.
MCP 서버의 “로컬 범위”라는 용어는 일반 로컬 설정과 다릅니다. MCP 로컬 범위 서버는
~/.claude.json (홈 디렉토리)에 저장되고, 일반 로컬 설정은 .claude/settings.local.json (프로젝트 디렉토리)을 사용합니다. 설정 파일 위치에 대한 자세한 내용은 설정을 참조하세요./path/to/your/project에서 실행할 때 명령은 ~/.claude.json 내의 현재 프로젝트 항목에 서버를 작성합니다. 아래 예는 결과를 보여줍니다:
프로젝트 범위
프로젝트 범위 서버는 프로젝트 루트 디렉토리의.mcp.json 파일에 구성을 저장하여 팀 협업을 가능하게 합니다. 이 파일은 버전 제어에 체크인되도록 설계되어 모든 팀 멤버가 동일한 MCP 도구 및 서비스에 액세스할 수 있도록 합니다. 프로젝트 범위 서버를 추가하면 Claude Code는 자동으로 이 파일을 생성하거나 적절한 구성 구조로 업데이트합니다.
.mcp.json 파일은 표준화된 형식을 따릅니다:
.mcp.json 파일의 프로젝트 범위 서버를 사용하기 전에 승인을 요청합니다. 이러한 승인 선택을 재설정해야 하는 경우 claude mcp reset-project-choices 명령을 사용하세요.
사용자 범위
사용자 범위 서버는~/.claude.json에 저장되며 교차 프로젝트 접근성을 제공하므로 컴퓨터의 모든 프로젝트에서 사용할 수 있으면서 사용자 계정에만 비공개입니다. 이 범위는 개인 유틸리티 서버, 개발 도구 또는 다양한 프로젝트에서 자주 사용하는 서비스에 적합합니다.
범위 계층 및 우선순위
동일한 서버가 둘 이상의 위치에 정의되면 Claude Code는 가장 높은 우선순위 소스의 정의를 사용하여 한 번 연결합니다. 해당 소스의 전체 서버 항목이 사용되며, 필드는 범위 간에 병합되지 않습니다.- 로컬 범위
- 프로젝트 범위
- 사용자 범위
- 플러그인 제공 서버
- Claude.ai 커넥터
.mcp.json의 환경 변수 확장
Claude Code는 .mcp.json 파일의 환경 변수 확장을 지원하므로 팀이 구성을 공유하면서 머신 특정 경로 및 API 키와 같은 민감한 값에 대한 유연성을 유지할 수 있습니다.
지원되는 구문:
${VAR}- 환경 변수VAR의 값으로 확장${VAR:-default}-VAR이 설정되면 확장, 그렇지 않으면default사용
command- 서버 실행 파일 경로args- 명령줄 인수env- 서버에 전달되는 환경 변수url- HTTP 서버 유형의 경우headers- HTTP 서버 인증의 경우
실제 예
예: Sentry로 오류 모니터링
예: 코드 검토를 위해 GitHub에 연결
GitHub의 원격 MCP 서버는 헤더로 전달된 GitHub 개인 액세스 토큰으로 인증합니다. 하나를 얻으려면 GitHub 토큰 설정을 열고, Claude가 작업하려는 리포지토리에 액세스할 수 있는 새로운 세분화된 토큰을 생성한 다음 서버를 추가하세요:예: PostgreSQL 데이터베이스 쿼리
원격 MCP 서버로 인증
많은 클라우드 기반 MCP 서버는 인증이 필요합니다. Claude Code는 보안 연결을 위해 OAuth 2.0을 지원합니다. Claude Code는 서버가401 Unauthorized 또는 403 Forbidden으로 응답할 때 원격 서버를 인증이 필요한 것으로 표시합니다. 두 상태 코드 모두 서버를 /mcp에 플래그하여 OAuth 흐름을 완료할 수 있습니다. 인증 서버를 가리키는 WWW-Authenticate 헤더를 반환하는 사용자 정의 서버는 다른 원격 서버와 동일한 자동 검색을 받습니다.
서버에 대해 headers.Authorization을 구성했는데 서버가 해당 헤더를 거부하면 Claude Code는 OAuth로 폴백하지 않고 연결이 실패한 것으로 보고합니다. MCP 엔드포인트에 대해 토큰이 유효한지 확인하거나 OAuth 흐름을 사용하려면 헤더를 제거합니다.
고정 OAuth 콜백 포트 사용
일부 MCP 서버는 미리 등록된 특정 리디렉션 URI가 필요합니다. 기본적으로 Claude Code는 OAuth 콜백을 위해 무작위로 사용 가능한 포트를 선택합니다.--callback-port를 사용하여 포트를 고정하여 http://localhost:PORT/callback 형식의 사전 등록된 리디렉션 URI와 일치하도록 합니다.
--callback-port를 단독으로 사용할 수 있습니다 (동적 클라이언트 등록 포함) 또는 --client-id와 함께 사용할 수 있습니다 (사전 구성된 자격 증명 포함).
사전 구성된 OAuth 자격 증명 사용
일부 MCP 서버는 동적 클라이언트 등록을 통한 자동 OAuth 설정을 지원하지 않습니다. “Incompatible auth server: does not support dynamic client registration”과 같은 오류가 표시되면 서버에 사전 구성된 자격 증명이 필요합니다. Claude Code는 또한 동적 클라이언트 등록 대신 클라이언트 ID 메타데이터 문서 (CIMD)를 사용하는 서버를 지원하며 자동으로 검색합니다. 자동 검색이 실패하면 먼저 서버의 개발자 포털을 통해 OAuth 앱을 등록한 다음 서버를 추가할 때 자격 증명을 제공합니다.서버로 OAuth 앱 등록
서버의 개발자 포털을 통해 앱을 생성하고 클라이언트 ID와 클라이언트 시크릿을 기록합니다.많은 서버는 리디렉션 URI도 필요합니다. 그렇다면 포트를 선택하고
http://localhost:PORT/callback 형식으로 리디렉션 URI를 등록합니다. 다음 단계에서 --callback-port와 함께 동일한 포트를 사용합니다.자격 증명으로 서버 추가
다음 방법 중 하나를 선택합니다.
--callback-port에 사용되는 포트는 사용 가능한 모든 포트일 수 있습니다. 이전 단계에서 등록한 리디렉션 URI와 일치하기만 하면 됩니다.- claude mcp add
- claude mcp add-json
- claude mcp add-json (콜백 포트만)
- CI / 환경 변수
--client-id를 사용하여 앱의 클라이언트 ID를 전달합니다. --client-secret 플래그는 마스킹된 입력으로 시크릿을 요청합니다:OAuth 메타데이터 검색 재정의
특정 OAuth 인증 서버 메타데이터 URL을 가리켜 기본 검색 체인을 우회하도록 Claude Code를 설정합니다. MCP 서버의 표준 엔드포인트가 오류를 반환하거나 내부 프록시를 통해 검색을 라우팅하려는 경우에authServerMetadataUrl을 설정합니다. 기본적으로 Claude Code는 먼저 /.well-known/oauth-protected-resource에서 RFC 9728 보호된 리소스 메타데이터를 확인한 다음 /.well-known/oauth-authorization-server에서 RFC 8414 인증 서버 메타데이터로 돌아갑니다.
.mcp.json의 서버 구성의 oauth 객체에 authServerMetadataUrl을 설정합니다:
https://를 사용해야 합니다. authServerMetadataUrl은 Claude Code v2.1.64 이상이 필요합니다. 메타데이터 URL의 scopes_supported는 업스트림 서버가 광고하는 범위를 재정의합니다.
OAuth 범위 제한
oauth.scopes를 설정하여 인증 흐름 중에 Claude Code가 요청하는 범위를 고정합니다. 이는 업스트림 인증 서버가 광고하는 것보다 더 많은 범위를 부여하고 싶지 않을 때 MCP 서버를 보안 팀이 승인한 부분 집합으로 제한하는 지원되는 방법입니다. 값은 RFC 6749 §3.3의 scope 매개변수 형식과 일치하는 단일 공백으로 구분된 문자열입니다.
oauth.scopes는 authServerMetadataUrl과 서버가 /.well-known에서 검색하는 범위 모두보다 우선합니다. 설정하지 않으면 MCP 서버가 요청된 범위 집합을 결정합니다.
인증 서버가 scopes_supported에서 offline_access를 광고하면 Claude Code는 액세스 토큰을 새로운 브라우저 로그인 없이 새로 고칠 수 있도록 고정된 범위에 추가합니다.
서버가 나중에 도구 호출에 대해 403 insufficient_scope을 반환하면 Claude Code는 동일한 고정된 범위로 다시 인증합니다. 필요한 도구가 고정된 범위 외의 범위를 요구할 때 oauth.scopes를 확대합니다.
사용자 정의 인증을 위한 동적 헤더 사용
MCP 서버가 OAuth (예: Kerberos, 단기 토큰 또는 내부 SSO)가 아닌 다른 인증 체계를 사용하는 경우headersHelper를 사용하여 연결 시간에 요청 헤더를 생성합니다. Claude Code는 명령을 실행하고 출력을 연결 헤더에 병합합니다.
- 명령은 JSON 객체의 문자열 키-값 쌍을 stdout에 작성해야 합니다
- 명령은 10초 시간 초과를 사용하여 셸에서 실행됩니다
- 동적 헤더는 동일한 이름의 정적
headers를 재정의합니다
| 변수 | 값 |
|---|---|
CLAUDE_CODE_MCP_SERVER_NAME | MCP 서버의 이름 |
CLAUDE_CODE_MCP_SERVER_URL | MCP 서버의 URL |
headersHelper는 임의의 셸 명령을 실행합니다. 프로젝트 또는 로컬 범위에서 정의될 때 작업 공간 신뢰 대화 상자를 수락한 후에만 실행됩니다.JSON 구성에서 MCP 서버 추가
MCP 서버에 대한 JSON 구성이 있는 경우 직접 추가할 수 있습니다:Claude Desktop에서 MCP 서버 가져오기
Claude Desktop에서 MCP 서버를 이미 구성한 경우 가져올 수 있습니다:Claude.ai에서 MCP 서버 사용
Claude.ai 계정으로 Claude Code에 로그인한 경우 Claude.ai에서 추가한 MCP 서버는 Claude Code에서 자동으로 사용 가능합니다:Claude.ai에서 MCP 서버 구성
claude.ai/customize/connectors에서 서버를 추가합니다. Team 및 Enterprise 플랜에서는 관리자만 서버를 추가할 수 있습니다.
Show unused connectors 행 뒤에 축소되므로 조직에서 프로비저닝한 목록이 패널을 채우지 않습니다. 행을 선택하여 확장합니다. 이전에 로그인한 커넥터는 현재 재인증이 필요한 경우에도 계속 표시됩니다.
Claude.ai 커넥터는 활성 인증 방법이 Claude.ai 구독인 경우에만 가져옵니다. ANTHROPIC_API_KEY, ANTHROPIC_AUTH_TOKEN, apiKeyHelper 또는 Bedrock이나 Vertex와 같은 타사 공급자가 활성화되어 있으면 로드되지 않습니다. 이전에 /login을 실행했더라도 마찬가지입니다. /mcp에 추가한 커넥터가 나열되지 않으면 /status를 실행하여 활성화된 인증 방법을 확인하고, 해당 환경 변수를 설정 해제하거나 apiKeyHelper 설정을 제거한 후 /login을 실행하여 Claude.ai 계정을 선택합니다.
Claude Code에서 추가한 서버는 동일한 URL을 가리키는 claude.ai 커넥터보다 우선순위를 갖습니다. 이 경우 /mcp는 커넥터를 숨김으로 표시하고 커넥터를 사용하려는 경우 중복을 제거하는 방법을 표시합니다.
Claude Code에서 claude.ai MCP 서버를 비활성화하려면 ENABLE_CLAUDEAI_MCP_SERVERS 환경 변수를 false로 설정합니다:
Claude Code를 MCP 서버로 사용
Claude Code 자체를 다른 애플리케이션이 연결할 수 있는 MCP 서버로 사용할 수 있습니다:MCP 출력 제한 및 경고
MCP 도구가 큰 출력을 생성할 때 Claude Code는 토큰 사용량을 관리하여 대화 컨텍스트가 압도되지 않도록 합니다:- 출력 경고 임계값: Claude Code는 MCP 도구 출력이 10,000 토큰을 초과할 때 경고를 표시합니다
- 구성 가능한 제한:
MAX_MCP_OUTPUT_TOKENS환경 변수를 사용하여 최대 허용 MCP 출력 토큰을 조정할 수 있습니다 - 기본 제한: 기본 최대값은 25,000 토큰입니다
- 범위: 환경 변수는 자신의 제한을 선언하지 않는 도구에 적용됩니다.
anthropic/maxResultSizeChars를 설정하는 도구는MAX_MCP_OUTPUT_TOKENS이 설정된 것과 관계없이 텍스트 콘텐츠에 대해 해당 값을 사용합니다. 이미지 데이터를 반환하는 도구는 여전히MAX_MCP_OUTPUT_TOKENS의 영향을 받습니다
- 대규모 데이터 세트 또는 데이터베이스 쿼리
- 상세한 보고서 또는 문서 생성
- 광범위한 로그 파일 또는 디버깅 정보 처리
특정 도구의 제한 늘리기
MCP 서버를 구축하는 경우 도구의tools/list 응답 항목에서 _meta["anthropic/maxResultSizeChars"]를 설정하여 개별 도구가 기본 디스크 유지 임계값보다 큰 결과를 반환할 수 있습니다. Claude Code는 해당 도구의 임계값을 주석 처리된 값으로 올립니다 (최대 500,000자의 하드 상한까지).
이는 데이터베이스 스키마 또는 전체 파일 트리와 같이 본질적으로 크지만 필요한 출력을 반환하는 도구에 유용합니다. 주석 처리 없이 기본 임계값을 초과하는 결과는 디스크에 유지되고 대화에서 파일 참조로 대체됩니다.
MAX_MCP_OUTPUT_TOKENS과 독립적으로 적용되므로 사용자는 도구가 선언하는 도구에 대해 환경 변수를 올릴 필요가 없습니다. 이미지 데이터를 반환하는 도구는 여전히 토큰 제한의 영향을 받습니다.
MCP 리소스 요청에 응답
MCP 서버는 작업 중에 구조화된 입력을 요청할 수 있습니다. 서버가 자체적으로 얻을 수 없는 정보가 필요할 때 Claude Code는 대화형 대화 상자를 표시하고 응답을 서버에 다시 전달합니다. 사용자 측에서 구성이 필요하지 않습니다: 서버가 요청할 때 리소스 요청 대화 상자가 자동으로 나타납니다. 서버는 두 가지 방식으로 입력을 요청할 수 있습니다:- 양식 모드: Claude Code는 서버에서 정의한 양식 필드가 있는 대화 상자를 표시합니다 (예: 사용자 이름 및 암호 프롬프트). 필드를 입력하고 제출합니다.
- URL 모드: Claude Code는 인증 또는 승인을 위해 브라우저 URL을 엽니다. 브라우저에서 흐름을 완료한 다음 CLI에서 확인합니다.
Elicitation 훅을 사용하세요.
리소스 요청을 사용하는 MCP 서버를 구축하는 경우 MCP 리소스 요청 사양에서 프로토콜 세부 정보 및 스키마 예를 참조하세요.
MCP 리소스 사용
MCP 서버는 파일을 참조하는 방식과 유사하게 @ 멘션을 사용하여 참조할 수 있는 리소스를 노출할 수 있습니다.MCP 리소스 참조
MCP Tool Search로 확장
Tool Search는 MCP 컨텍스트 사용량을 낮게 유지하여 도구 정의를 Claude가 필요할 때까지 연기합니다. 세션 시작 시 도구 이름과 서버 지침만 로드되므로 더 많은 MCP 서버를 추가해도 컨텍스트 윈도우에 미치는 영향이 최소화됩니다.작동 방식
Tool Search는 기본적으로 활성화됩니다. MCP 도구는 미리 로드되지 않고 연기되며, Claude는 검색 도구를 사용하여 작업에 필요할 때 관련 도구를 검색합니다. Claude가 실제로 사용하는 도구만 컨텍스트에 들어갑니다. 사용자 관점에서 MCP 도구는 이전과 정확히 동일하게 작동합니다. 임계값 기반 로딩을 선호하는 경우ENABLE_TOOL_SEARCH=auto를 설정하여 컨텍스트 윈도우의 10% 이내에 맞을 때 스키마를 미리 로드하고 오버플로우만 연기합니다. 모든 옵션은 Tool Search 구성을 참조하세요.
MCP 서버 작성자용
MCP 서버를 구축하는 경우 Tool Search가 활성화되면 서버 지침 필드가 더 유용해집니다. 서버 지침은 Claude가 skills의 작동 방식과 유사하게 도구를 검색할 시기를 이해하는 데 도움이 됩니다. 다음을 설명하는 명확하고 설명적인 서버 지침을 추가합니다:- 도구가 처리하는 작업의 범주
- Claude가 도구를 검색해야 할 때
- 서버가 제공하는 주요 기능
Tool Search 구성
Tool Search는 기본적으로 활성화됩니다: MCP 도구는 연기되고 필요에 따라 검색됩니다. Claude Code는 Vertex AI에서 기본적으로 비활성화합니다.ANTHROPIC_BASE_URL이 비 자사 호스트를 가리킬 때도 비활성화됩니다(대부분의 프록시가 tool_reference 블록을 전달하지 않기 때문). 폴백을 재정의하려면 ENABLE_TOOL_SEARCH를 명시적으로 설정합니다.
Tool Search는 tool_reference 블록을 지원하는 모델이 필요합니다: Sonnet 4 이상 또는 Opus 4 이상. Haiku 모델은 이를 지원하지 않습니다. Vertex AI에서는 Claude Sonnet 4.5 이상 및 Claude Opus 4.5 이상에서 Tool Search가 지원됩니다.
ENABLE_TOOL_SEARCH 환경 변수로 Tool Search 동작을 제어합니다:
| 값 | 동작 |
|---|---|
| (설정되지 않음) | 모든 MCP 도구 연기되고 필요에 따라 로드됨. Vertex AI 또는 ANTHROPIC_BASE_URL이 비 자사 호스트일 때 미리 로드로 돌아감 |
true | 모든 MCP 도구 연기. Claude Code는 Vertex AI 및 프록시를 통해서도 베타 헤더를 전송합니다. Vertex AI의 Sonnet 4.5 또는 Opus 4.5보다 이전 모델에서 요청이 실패하거나 tool_reference 블록을 지원하지 않는 프록시에서 실패합니다 |
auto | 임계값 모드: 도구가 컨텍스트 윈도우의 10% 이내에 맞으면 미리 로드, 그렇지 않으면 연기 |
auto:N | 사용자 정의 백분율을 사용한 임계값 모드, N은 0-100 (예: auto:5는 5%) |
false | 모든 MCP 도구 미리 로드, 연기 없음 |
env 필드에서 값을 설정합니다.
ToolSearch 도구를 특별히 비활성화할 수도 있습니다:
서버를 연기에서 제외
서버의 도구가 검색 단계 없이 항상 Claude에게 표시되어야 하는 경우 해당 서버의 구성에서alwaysLoad를 true로 설정합니다. 그러면 ENABLE_TOOL_SEARCH 설정에 관계없이 해당 서버의 모든 도구가 세션 시작 시 컨텍스트에 로드됩니다. 매 턴마다 Claude가 필요로 하는 소수의 도구에 이를 사용합니다. 각 미리 로드된 도구는 대화에 사용할 수 있는 컨텍스트를 소비하기 때문입니다.
다음 .mcp.json 항목은 한 HTTP 서버를 제외하면서 다른 서버는 연기된 상태로 유지합니다:
alwaysLoad 필드는 모든 서버 유형에서 사용 가능하며 Claude Code v2.1.121 이상이 필요합니다. MCP 서버는 도구의 _meta 객체에 "anthropic/alwaysLoad": true를 포함하여 개별 도구를 항상 로드되도록 표시할 수도 있으며, 이는 해당 도구에만 동일한 효과를 갖습니다.
alwaysLoad: true를 설정하면 서버가 연결될 때까지 시작이 차단되며, 표준 5초 연결 타임아웃으로 제한됩니다. 이는 MCP 시작이 기본적으로 비차단이더라도 적용됩니다. 첫 번째 프롬프트가 빌드될 때 도구가 있어야 하기 때문입니다. 다른 서버는 계속해서 백그라운드에서 연결됩니다.
MCP 프롬프트를 명령으로 사용
MCP 서버는 Claude Code에서 명령으로 사용 가능하게 되는 프롬프트를 노출할 수 있습니다.MCP 프롬프트 실행
사용 가능한 프롬프트 검색
/를 입력하여 MCP 서버의 프롬프트를 포함한 모든 사용 가능한 명령을 확인합니다. MCP 프롬프트는 /mcp__servername__promptname 형식으로 나타납니다.관리되는 MCP 구성
중앙 집중식 제어가 필요한 조직의 경우 MCP 서버에 사용자가 연결할 수 있는 서버를 제어하려면 관리되는 MCP 구성을 참조하십시오. 이는managed-mcp.json을 사용하여 고정된 서버 세트 배포, allowedMcpServers 및 deniedMcpServers로 서버 제한, 서버가 차단될 때 사용자가 보는 내용을 다룹니다.