OpenAI Agents SDK
OpenAI Agents SDK는 추상화가 매우 적은 가볍고 사용하기 쉬운 패키지로 에이전트형 AI 앱을 구축할 수 있도록 해줍니다. 이는 이전 에이전트 실험 프로젝트인 Swarm의 프로덕션 준비가 된 업그레이드입니다. Agents SDK에는 매우 소수의 기본 구성 요소가 있습니다:
- 에이전트: instructions와 tools를 갖춘 LLM
- 핸드오프: 특정 작업에 대해 다른 에이전트에 위임할 수 있도록 함
- 가드레일: 에이전트 입력과 출력의 검증을 가능하게 함
- 세션: 에이전트 실행 간 대화 기록을 자동으로 유지 관리함
Python과 결합하면, 이 기본 구성 요소만으로도 도구와 에이전트 간의 복잡한 관계를 표현할 수 있으며 급격한 학습 곡선 없이 실제 애플리케이션을 구축할 수 있습니다. 또한 SDK에는 에이전트 플로우를 시각화하고 디버그하며, 평가하고 심지어 애플리케이션에 맞게 모델을 파인튜닝할 수 있게 해주는 트레이싱이 기본으로 포함되어 있습니다.
Agents SDK 사용 이유
SDK는 두 가지 설계 원칙을 따릅니다:
- 사용할 가치가 있을 만큼 충분한 기능을 제공하되, 빠르게 배울 수 있도록 기본 구성 요소는 최소화합니다
- 즉시 잘 동작하도록 제공하되, 원하는 동작을 정확히 커스터마이즈할 수 있습니다
SDK의 주요 기능은 다음과 같습니다:
- 에이전트 루프: 도구 호출, 결과를 LLM으로 전달, LLM이 완료될 때까지 루프를 처리하는 내장 에이전트 루프
- 파이썬 우선: 새로운 추상화를 배우지 않고도, 내장 언어 기능으로 에이전트를 오케스트레이션하고 체이닝
- 핸드오프: 여러 에이전트 간 조정과 위임을 위한 강력한 기능
- 가드레일: 에이전트와 병렬로 입력 검증 및 체크를 실행하고 실패 시 조기 종료
- 세션: 에이전트 실행 간 대화 기록을 자동으로 관리하여 수동 상태 관리를 제거
- 함수 도구: 어떤 Python 함수든 자동 스키마 생성과 Pydantic 기반 검증으로 도구로 전환
- 트레이싱: 워크플로를 시각화, 디버그, 모니터링하고 OpenAI 제품군의 평가, 파인튜닝, 증류 도구를 활용할 수 있는 기본 트레이싱
설치
Hello World 예제
from agents import Agent, Runner
agent = Agent(name="Assistant", instructions="You are a helpful assistant")
result = Runner.run_sync(agent, "Write a haiku about recursion in programming.")
print(result.final_output)
# Code within the code,
# Functions calling themselves,
# Infinite loop's dance.
(실행하는 경우, OPENAI_API_KEY 환경 변수를 설정했는지 확인하세요)