Loading...
    • 빌드
    • 관리
    • 모델 및 가격
    • 클라이언트 SDK
    • API 참조
    Search...
    ⌘K
    시작하기
    Claude 소개빠른 시작
    Claude로 구축하기
    기능 개요Messages API 사용중지 이유 처리
    모델 기능
    확장 사고적응형 사고노력빠른 모드 (베타: 리서치 프리뷰)구조화된 출력인용스트리밍 메시지일괄 처리검색 결과스트리밍 거부다국어 지원임베딩
    도구
    개요도구 사용 방법웹 검색 도구웹 가져오기 도구코드 실행 도구메모리 도구Bash 도구컴퓨터 사용 도구텍스트 편집기 도구
    도구 인프라
    도구 검색프로그래밍 방식 도구 호출세밀한 도구 스트리밍
    컨텍스트 관리
    컨텍스트 윈도우압축컨텍스트 편집프롬프트 캐싱토큰 계산
    파일 작업
    Files APIPDF 지원이미지 및 비전
    스킬
    개요빠른 시작모범 사례엔터프라이즈용 스킬API의 스킬
    MCP
    원격 MCP 서버MCP 커넥터
    프롬프트 엔지니어링
    개요프롬프트 모범 사례Console 프롬프트 도구
    테스트 및 평가
    성공 기준 정의 및 평가 구축Console의 평가 도구 사용지연 시간 줄이기
    가드레일 강화
    환각 줄이기출력 일관성 높이기탈옥 방지프롬프트 유출 줄이기
    리소스
    용어집
    릴리스 노트
    Claude Platform
    Console
    Log in
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...
    Loading...

    Solutions

    • AI agents
    • Code modernization
    • Coding
    • Customer support
    • Education
    • Financial services
    • Government
    • Life sciences

    Partners

    • Amazon Bedrock
    • Google Cloud's Vertex AI

    Learn

    • Blog
    • Catalog
    • Courses
    • Use cases
    • Connectors
    • Customer stories
    • Engineering at Anthropic
    • Events
    • Powered by Claude
    • Service partners
    • Startups program

    Company

    • Anthropic
    • Careers
    • Economic Futures
    • Research
    • News
    • Responsible Scaling Policy
    • Security and compliance
    • Transparency

    Learn

    • Blog
    • Catalog
    • Courses
    • Use cases
    • Connectors
    • Customer stories
    • Engineering at Anthropic
    • Events
    • Powered by Claude
    • Service partners
    • Startups program

    Help and security

    • Availability
    • Status
    • Support
    • Discord

    Terms and policies

    • Privacy policy
    • Responsible disclosure policy
    • Terms of service: Commercial
    • Terms of service: Consumer
    • Usage policy
    도구

    도구 사용의 작동 방식

    도구 사용 루프, 도구가 실행되는 위치, 그리고 산문 대신 도구를 사용해야 하는 경우를 이해합니다.

    이 페이지는 도구 사용의 개념을 설명합니다: 도구가 실행되는 위치, 에이전트 루프의 작동 방식, 그리고 도구 사용이 적합한 접근 방식인 경우. 실습 안내는 튜토리얼 또는 구현 가이드를 참조하세요.

    도구 사용 계약

    도구 사용은 애플리케이션과 모델 간의 계약입니다. 어떤 작업을 사용할 수 있는지, 입력과 출력의 형태가 어떠한지를 지정하면, Claude가 언제 어떻게 호출할지를 결정합니다. 모델은 스스로 아무것도 실행하지 않습니다. 구조화된 요청을 내보내면, 여러분의 코드(또는 Anthropic의 서버)가 작업을 실행하고, 결과가 대화로 다시 흘러들어옵니다.

    이 계약은 모델이 텍스트 생성기보다는 호출하는 함수처럼 동작하게 만듭니다. 고전적인 API 경험을 가진 엔지니어는 다른 타입 인터페이스와 동일한 방식으로 도구 사용을 통합할 수 있습니다: 스키마를 정의하고, 콜백을 처리하고, 결과를 반환합니다. 차이점은 반대편의 호출자가 대화를 기반으로 어떤 함수를 호출할지 선택하는 언어 모델이라는 것입니다.

    도구가 실행되는 위치

    도구가 서로 다른 주요 축은 코드가 실행되는 위치입니다. 모든 도구는 세 가지 범주 중 하나에 속하며, 해당 범주가 애플리케이션이 담당해야 할 사항을 결정합니다.

    사용자 정의 도구 (클라이언트 실행)

    스키마를 작성하고, 코드를 실행하고, 결과를 반환하는 것은 모두 여러분의 몫입니다. 이것이 핵심입니다: 도구 사용 트래픽의 대부분은 애플리케이션별 로직을 호출하는 사용자 정의 도구입니다.

    Claude가 여러분의 도구 중 하나를 사용하기로 결정하면, API 응답에는 도구 이름과 인수의 JSON 객체가 포함된 tool_use 블록이 포함됩니다. 애플리케이션은 해당 인수를 추출하고, 작업(데이터베이스 쿼리, HTTP 호출, 파일 쓰기 등 도구가 수행하는 모든 작업)을 실행하고, 다음 요청의 tool_result 블록에 출력을 다시 보냅니다. Claude는 여러분의 구현을 볼 수 없으며, 제공한 스키마와 반환한 결과만 볼 수 있습니다.

    Anthropic 스키마 도구 (클라이언트 실행)

    일부 일반적인 작업(셸 명령 실행, 파일 편집, 브라우저 제어, 스크래치패드 메모리 관리)의 경우, Anthropic이 도구 스키마를 게시하고 애플리케이션이 실행을 처리합니다. 이 범주의 도구는 bash, text_editor, computer, memory입니다.

    실행 모델은 사용자 정의 도구와 동일합니다: 응답에는 블록이 포함되고, 코드가 작업을 실행하며, 를 다시 보냅니다. 동일한 기능을 수행하는 사용자 정의 도구 대신 Anthropic 스키마 도구를 사용하는 이유는 이러한 스키마가 훈련에 내장되어 있기 때문입니다. Claude는 이 정확한 도구 서명을 사용하는 수천 개의 성공적인 궤적에 대해 최적화되어 있으므로, 동일한 작업을 수행하는 사용자 정의 도구보다 더 안정적으로 호출하고 오류에서 더 우아하게 복구합니다. 스키마는 모델이 이미 기대하는 인터페이스입니다.

    Was this page helpful?

    • Anthropic 스키마 도구 (클라이언트 실행)
    tool_use
    tool_result

    서버 실행 도구

    web_search, web_fetch, code_execution, tool_search의 경우, Anthropic이 코드를 실행합니다. 요청에서 도구를 활성화하면 서버가 나머지 모든 것을 처리합니다. 서버 측 루프가 작업을 실행하고 응답이 여러분에게 도달하기 전에 출력을 모델에 다시 공급하기 때문에, 이러한 도구에 대한 tool_result 블록을 구성할 필요가 없습니다.

    수신하는 응답에는 실행된 내용과 반환된 내용을 보여주는 server_tool_use 블록이 포함되지만, 여러분이 볼 때쯤에는 실행이 이미 완료된 상태입니다. 애플리케이션의 역할은 도구를 활성화하고 최종 답변을 읽는 것이며, 실행 루프에 참여하는 것이 아닙니다.

    에이전트 루프 (클라이언트 도구)

    클라이언트 실행 도구(사용자 정의 및 Anthropic 스키마 모두)는 애플리케이션이 루프를 구동해야 합니다. 모델은 코드를 실행할 수 없으므로, 모든 도구 호출은 왕복입니다: 모델이 요청하고, 여러분이 실행하고, 여러분이 보고하고, 모델이 계속합니다.

    표준적인 형태는 stop_reason을 키로 하는 while 루프입니다:

    1. tools 배열과 사용자 메시지로 요청을 보냅니다.
    2. Claude가 stop_reason: "tool_use"와 하나 이상의 tool_use 블록으로 응답합니다.
    3. 각 도구를 실행합니다. 출력을 tool_result 블록으로 형식화합니다.
    4. 원래 메시지, 어시스턴트의 응답, tool_result 블록이 포함된 사용자 메시지를 포함하는 새 요청을 보냅니다.
    5. stop_reason이 "tool_use"인 동안 2단계부터 반복합니다.

    실제로 이것은 다음과 같이 읽힙니다: stop_reason == "tool_use"인 동안, 도구를 실행하고 대화를 계속합니다. 루프는 다른 중지 이유("end_turn", "max_tokens", "stop_sequence", 또는 "refusal")에서 종료되며, 이는 Claude가 최종 답변을 생성했거나 애플리케이션이 처리해야 하는 다른 이유로 중지되었음을 의미합니다.

    요청 구성, 병렬 도구 호출 처리, 결과 형식화의 메커니즘에 대해서는 도구 호출 처리를 참조하세요.

    서버 측 루프

    서버 실행 도구는 Anthropic의 인프라 내에서 자체 루프를 실행합니다. 애플리케이션의 단일 요청이 응답이 돌아오기 전에 여러 번의 웹 검색이나 코드 실행을 트리거할 수 있습니다. 모델은 검색하고, 결과를 읽고, 다시 검색하기로 결정하고, 필요한 것을 얻을 때까지 반복합니다. 이 모든 것이 애플리케이션의 참여 없이 이루어집니다.

    이 내부 루프에는 반복 제한이 있습니다. 모델이 한도에 도달할 때까지 여전히 반복 중이면, 응답이 "end_turn" 대신 stop_reason: "pause_turn"으로 돌아옵니다. 일시 중지된 턴은 작업이 완료되지 않았음을 의미합니다; 모델이 중단된 곳에서 계속할 수 있도록 대화(일시 중지된 응답 포함)를 다시 보내세요. 연속 패턴에 대해서는 서버 도구를 참조하세요.

    도구를 사용해야 할 때 (그리고 사용하지 말아야 할 때)

    도구 사용은 작업이 모델이 텍스트만으로는 할 수 없는 무언가를 필요로 할 때 적합합니다:

    • 부작용이 있는 작업. 이메일 보내기, 파일 쓰기, 레코드 업데이트. 모델은 이러한 작업을 설명할 수 있지만, 도구만이 실제로 수행할 수 있습니다.
    • 최신 또는 외부 데이터. 현재 가격, 오늘의 날씨, 데이터베이스의 내용. 훈련 데이터 외부에 있거나 시스템에 특정한 모든 것은 가져오기 위한 도구가 필요합니다.
    • 구조화된, 보장된 형태의 출력. 정보를 포함하는 산문이 아닌 특정 필드가 있는 JSON 객체가 필요할 때, 도구 스키마가 형태를 강제합니다.
    • 기존 시스템 호출. 데이터베이스, 내부 API, 파일 시스템. 도구 사용은 자연어 요청과 이를 처리하는 시스템 사이의 다리입니다.

    도구를 사용해야 한다는 신호: 모델 출력에서 결정을 추출하기 위해 정규식을 작성하고 있다면, 그 결정은 도구 호출이었어야 합니다. 구조화된 의도를 복구하기 위해 자유 형식 텍스트를 파싱하는 것은 구조가 스키마에 속한다는 신호입니다.

    도구 사용이 적합하지 않은 경우:

    • 모델이 훈련만으로 답할 수 있는 경우. 요약, 번역, 일반 지식 질문은 도구 왕복이 필요하지 않습니다.
    • 상호작용이 부작용 없는 일회성 Q&A인 경우. 실행할 것이 없다면, 도구가 할 일도 없습니다.
    • 도구 호출 지연이 사소한 응답을 지배하는 경우. 모든 도구 호출은 최소 하나의 추가 왕복입니다; 가벼운 작업의 경우 오버헤드가 작업을 초과할 수 있습니다.

    접근 방식 선택

    접근 방식사용 시기예상 사항자세히 알아보기
    사용자 정의 클라이언트 도구사용자 정의 비즈니스 로직, 내부 API, 독점 데이터실행 및 에이전트 루프를 직접 처리도구 정의
    Anthropic 스키마 클라이언트 도구표준 개발 작업 (bash, 파일 편집, 브라우저 제어)실행을 직접 처리; 스키마가 훈련에 내장되어 있으므로 Claude가 도구를 안정적으로 호출도구 참조
    서버 실행 도구웹 검색, 코드 샌드박스, 웹 가져오기Anthropic이 실행을 처리; 결과를 직접 수신서버 도구

    다음 단계

    튜토리얼: 도구 사용 에이전트 구축

    단일 도구 호출에서 프로덕션까지 단계별로 에이전트를 구축합니다.

    도구 정의

    스키마 사양, 설명, tool_choice.

    도구 참조

    Anthropic 제공 도구 디렉토리.