개요
Claude Agent SDK는 에이전트와 상호작용하기 위한 두 가지 서로 다른 입력 모드를 지원합니다:- 스트리밍 입력 모드 (기본값 및 권장) - 지속적이고 대화형 세션
- 단일 메시지 입력 - 세션 상태를 사용하고 재개하는 일회성 쿼리
스트리밍 입력 모드 (권장)
스트리밍 입력 모드는 Claude Agent SDK를 사용하는 선호되는 방식입니다. 에이전트의 기능에 대한 전체 액세스를 제공하고 풍부하고 대화형의 경험을 가능하게 합니다. 이를 통해 에이전트는 사용자 입력을 받아들이고, 중단을 처리하며, 권한 요청을 표시하고, 세션 관리를 처리하는 장기 실행 프로세스로 작동할 수 있습니다.작동 방식
이점
이미지 업로드
시각적 분석 및 이해를 위해 메시지에 직접 이미지를 첨부합니다
대기 중인 메시지
순차적으로 처리되는 여러 메시지를 보내고 중단할 수 있습니다
도구 통합
세션 중에 모든 도구 및 사용자 정의 MCP 서버에 대한 전체 액세스
실시간 피드백
최종 결과뿐만 아니라 생성되는 응답을 실시간으로 확인합니다
컨텍스트 지속성
여러 턴에 걸쳐 자연스럽게 대화 컨텍스트를 유지합니다
구현 예제
TypeScript SDK에서 예를 들어 읽는 파일이 누락되었을 때 메시지 생성기가 throw하면, 스트림은 원래 오류 대신
Claude Code process aborted by user라고 읽는 오류로 끝나므로, 해당 메시지가 표시되면 먼저 생성기 내부의 코드를 확인하십시오. 오류 앞에 번들된 SDK 소스의 긴 축소된 줄이 있을 수도 있으므로, 오류 텍스트를 찾기 위해 출력의 끝까지 읽으십시오.Python SDK에서는 생성기 예외가 디버그 수준에서 기록되고 세션이 raise하지 않고 정지되므로, 스트리밍 세션이 출력 없이 중단되면 디버그 로깅을 활성화하고 생성기를 확인하십시오.단일 메시지 입력
단일 메시지 입력은 더 간단하지만 더 제한적입니다.단일 메시지 입력을 사용할 때
다음의 경우 단일 메시지 입력을 사용합니다:- 일회성 응답이 필요한 경우
- 이미지 첨부 또는 중간 세션 제어 방법이 필요하지 않은 경우
- lambda 함수와 같은 상태 비저장 환경에서 작동해야 하는 경우
제한 사항
쿼리가error_max_turns와 같은 오류 결과로 끝나면, 단일 메시지 query() 호출은 최종 결과 메시지를 생성한 후 실패 텍스트를 포함하는 오류를 발생시키므로, 코드가 계속 실행되어야 하는 경우 루프를 try 블록으로 감싸십시오. 결과 하위 유형에 대해서는 결과 처리를 참조하십시오.