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
환경 변수를 설정하세요)