agents.*, multiAgent.*, session.*,
messages.*, talk.* 아래의 에이전트 범위 설정 키입니다. 채널, 도구, Gateway 런타임, 기타
최상위 키는 Configuration reference를 참조하세요.
에이전트 기본값
agents.defaults.workspace
기본값: ~/.openclaw/workspace.
agents.defaults.repoRoot
시스템 프롬프트의 Runtime 줄에 표시되는 선택적 저장소 루트입니다. 설정하지 않으면 OpenClaw가 워크스페이스에서 위로 올라가며 자동 감지합니다.
agents.defaults.skills
agents.list[].skills를 설정하지 않은 에이전트에 대한
선택적 기본 Skills 허용 목록입니다.
- 기본적으로 Skills를 제한하지 않으려면
agents.defaults.skills를 생략하세요. - 기본값을 상속하려면
agents.list[].skills를 생략하세요. - Skills를 사용하지 않으려면
agents.list[].skills: []로 설정하세요. - 비어 있지 않은
agents.list[].skills목록은 해당 에이전트의 최종 집합이며, 기본값과 병합되지 않습니다.
agents.defaults.skipBootstrap
워크스페이스 부트스트랩 파일(AGENTS.md, SOUL.md, TOOLS.md, IDENTITY.md, USER.md, HEARTBEAT.md, BOOTSTRAP.md)의 자동 생성을 비활성화합니다.
agents.defaults.contextInjection
워크스페이스 부트스트랩 파일이 언제 시스템 프롬프트에 주입되는지 제어합니다. 기본값: "always".
"continuation-skip": 안전한 이어서 진행 턴(완료된 assistant 응답 이후)에서는 워크스페이스 부트스트랩 재주입을 건너뛰어 프롬프트 크기를 줄입니다. Heartbeat 실행과 Compaction 후 재시도는 여전히 컨텍스트를 다시 빌드합니다.
agents.defaults.bootstrapMaxChars
잘리기 전에 워크스페이스 부트스트랩 파일 하나당 허용되는 최대 문자 수입니다. 기본값: 12000.
agents.defaults.bootstrapTotalMaxChars
모든 워크스페이스 부트스트랩 파일에 걸쳐 주입되는 총 최대 문자 수입니다. 기본값: 60000.
agents.defaults.bootstrapPromptTruncationWarning
부트스트랩 컨텍스트가 잘렸을 때 에이전트에 보이는 경고 텍스트를 제어합니다.
기본값: "once".
"off": 시스템 프롬프트에 경고 텍스트를 절대 주입하지 않음"once": 고유한 잘림 시그니처마다 한 번만 경고 주입(권장)"always": 잘림이 있을 때마다 매 실행마다 경고 주입
컨텍스트 예산 소유 맵
OpenClaw에는 고용량 프롬프트/컨텍스트 예산이 여러 개 있으며, 의도적으로 하나의 일반 설정값으로 모두 통합하지 않고 하위 시스템별로 나뉘어 있습니다.agents.defaults.bootstrapMaxChars/agents.defaults.bootstrapTotalMaxChars: 일반 워크스페이스 부트스트랩 주입agents.defaults.startupContext.*: 최근 일일memory/*.md파일을 포함한 일회성/new및/reset시작 프렐류드skills.limits.*: 시스템 프롬프트에 주입되는 압축된 Skills 목록agents.defaults.contextLimits.*: 제한된 런타임 발췌문 및 주입되는 런타임 소유 블록memory.qmd.limits.*: 인덱싱된 메모리 검색 스니펫 및 주입 크기
agents.list[].skillsLimits.maxSkillsPromptCharsagents.list[].contextLimits.*
agents.defaults.startupContext
기본 /new 및 /reset
실행 시 주입되는 첫 턴 시작 프렐류드를 제어합니다.
agents.defaults.contextLimits
제한된 런타임 컨텍스트 표면에 대한 공용 기본값입니다.
memoryGetMaxChars: 잘림 메타데이터와 이어보기 공지가 추가되기 전memory_get발췌문의 기본 상한memoryGetDefaultLines:lines가 생략되었을 때memory_get의 기본 줄 범위toolResultMaxChars: 저장된 결과 및 오버플로 복구에 사용되는 라이브 도구 결과 상한postCompactionMaxChars: Compaction 후 새로고침 주입 중 사용되는 AGENTS.md 발췌문 상한
agents.list[].contextLimits
공용 contextLimits 설정값에 대한 에이전트별 재정의입니다. 생략된 필드는
agents.defaults.contextLimits를 상속합니다.
skills.limits.maxSkillsPromptChars
시스템 프롬프트에 주입되는 압축 Skills 목록의 전역 상한입니다. 이는
필요 시 SKILL.md 파일을 읽는 동작에는 영향을 주지 않습니다.
agents.list[].skillsLimits.maxSkillsPromptChars
Skills 프롬프트 예산에 대한 에이전트별 재정의입니다.
agents.defaults.imageMaxDimensionPx
provider 호출 전에 대화록/도구 이미지 블록에서 이미지의 가장 긴 변 길이에 대한 최대 픽셀 크기입니다.
기본값: 1200.
값을 낮추면 일반적으로 스크린샷이 많은 실행에서 비전 토큰 사용량과 요청 페이로드 크기가 줄어듭니다.
값을 높이면 더 많은 시각적 세부 사항을 보존합니다.
agents.defaults.userTimezone
시스템 프롬프트 컨텍스트용 시간대입니다(메시지 타임스탬프용 아님). 호스트 시간대로 대체됩니다.
agents.defaults.timeFormat
시스템 프롬프트의 시간 형식입니다. 기본값: auto(OS 기본 설정).
agents.defaults.model
model: 문자열("provider/model") 또는 객체({ primary, fallbacks })를 받을 수 있습니다.- 문자열 형식은 기본 모델만 설정합니다.
- 객체 형식은 기본 모델과 순서가 있는 장애 조치 모델을 함께 설정합니다.
imageModel: 문자열("provider/model") 또는 객체({ primary, fallbacks })를 받을 수 있습니다.image도구 경로에서 비전 모델 설정으로 사용됩니다.- 선택된/기본 모델이 이미지 입력을 받을 수 없을 때 대체 라우팅에도 사용됩니다.
imageGenerationModel: 문자열("provider/model") 또는 객체({ primary, fallbacks })를 받을 수 있습니다.- 공용 이미지 생성 기능과 향후 이미지를 생성하는 모든 도구/Plugin 표면에서 사용됩니다.
- 일반적인 값: Gemini 네이티브 이미지 생성에는
google/gemini-3.1-flash-image-preview, fal에는fal/fal-ai/flux/dev, OpenAI Images에는openai/gpt-image-2. - provider/model을 직접 선택하면 일치하는 provider 인증도 함께 구성하세요(예:
google/*에는GEMINI_API_KEY또는GOOGLE_API_KEY,openai/gpt-image-2에는OPENAI_API_KEY또는 OpenAI Codex OAuth,fal/*에는FAL_KEY). - 설정하지 않아도
image_generate는 인증 기반 provider 기본값을 추론할 수 있습니다. 현재 기본 provider를 먼저 시도한 뒤, 남은 등록된 이미지 생성 provider를 provider-id 순서로 시도합니다.
musicGenerationModel: 문자열("provider/model") 또는 객체({ primary, fallbacks })를 받을 수 있습니다.- 공용 음악 생성 기능과 내장
music_generate도구에서 사용됩니다. - 일반적인 값:
google/lyria-3-clip-preview,google/lyria-3-pro-preview, 또는minimax/music-2.5+. - 설정하지 않아도
music_generate는 인증 기반 provider 기본값을 추론할 수 있습니다. 현재 기본 provider를 먼저 시도한 뒤, 남은 등록된 음악 생성 provider를 provider-id 순서로 시도합니다. - provider/model을 직접 선택하면 일치하는 provider 인증/API 키도 함께 구성하세요.
- 공용 음악 생성 기능과 내장
videoGenerationModel: 문자열("provider/model") 또는 객체({ primary, fallbacks })를 받을 수 있습니다.- 공용 비디오 생성 기능과 내장
video_generate도구에서 사용됩니다. - 일반적인 값:
qwen/wan2.6-t2v,qwen/wan2.6-i2v,qwen/wan2.6-r2v,qwen/wan2.6-r2v-flash, 또는qwen/wan2.7-r2v. - 설정하지 않아도
video_generate는 인증 기반 provider 기본값을 추론할 수 있습니다. 현재 기본 provider를 먼저 시도한 뒤, 남은 등록된 비디오 생성 provider를 provider-id 순서로 시도합니다. - provider/model을 직접 선택하면 일치하는 provider 인증/API 키도 함께 구성하세요.
- 번들된 Qwen 비디오 생성 provider는 최대 출력 비디오 1개, 입력 이미지 1개, 입력 비디오 4개, 최대 길이 10초, 그리고 provider 수준의
size,aspectRatio,resolution,audio,watermark옵션을 지원합니다.
- 공용 비디오 생성 기능과 내장
pdfModel: 문자열("provider/model") 또는 객체({ primary, fallbacks })를 받을 수 있습니다.pdf도구의 모델 라우팅에 사용됩니다.- 설정하지 않으면 PDF 도구는
imageModel, 그다음 확인된 세션/기본 모델 순서로 대체합니다.
pdfMaxBytesMb: 호출 시maxBytesMb가 전달되지 않았을 때pdf도구의 기본 PDF 크기 제한입니다.pdfMaxPages:pdf도구의 추출 대체 모드에서 고려하는 기본 최대 페이지 수입니다.verboseDefault: 에이전트의 기본 verbose 수준입니다. 값:"off","on","full". 기본값:"off".elevatedDefault: 에이전트의 기본 상승 출력 수준입니다. 값:"off","on","ask","full". 기본값:"on".model.primary: 형식은provider/model입니다(예: API 키 접근용openai/gpt-5.4, Codex OAuth용openai-codex/gpt-5.5). provider를 생략하면 OpenClaw는 먼저 별칭을 시도하고, 그다음 해당 정확한 모델 id에 대한 고유한 구성 provider 일치를 찾고, 마지막에만 구성된 기본 provider로 대체합니다(deprecated 호환 동작이므로 명시적인provider/model을 권장). 해당 provider가 더 이상 구성된 기본 모델을 제공하지 않으면, OpenClaw는 오래된 제거된 provider 기본값을 노출하는 대신 첫 번째 구성된 provider/model으로 대체합니다.models:/model용 구성된 모델 카탈로그 및 허용 목록입니다. 각 항목에는alias(바로가기)와params(provider별 값, 예:temperature,maxTokens,cacheRetention,context1m,responsesServerCompaction,responsesCompactThreshold)를 포함할 수 있습니다.- 안전한 편집: 항목을 추가하려면
openclaw config set agents.defaults.models '<json>' --strict-json --merge를 사용하세요.config set은--replace를 전달하지 않는 한 기존 허용 목록 항목을 제거하는 대체를 거부합니다. - provider 범위 configure/onboarding 흐름은 선택된 provider 모델을 이 맵에 병합하고 이미 구성된 관련 없는 provider는 보존합니다.
- 직접 OpenAI Responses 모델의 경우 서버 측 Compaction이 자동으로 활성화됩니다.
context_management주입을 중지하려면params.responsesServerCompaction: false를 사용하고, 임계값을 재정의하려면params.responsesCompactThreshold를 사용하세요. OpenAI server-side compaction을 참조하세요.
- 안전한 편집: 항목을 추가하려면
params: 모든 모델에 적용되는 전역 기본 provider 매개변수입니다.agents.defaults.params에 설정합니다(예:{ cacheRetention: "long" }).params병합 우선순위(설정):agents.defaults.params(전역 기본값)는agents.defaults.models["provider/model"].params(모델별)로 재정의되고, 그다음agents.list[].params(일치하는 에이전트 id)가 키별로 재정의합니다. 자세한 내용은 Prompt Caching을 참조하세요.embeddedHarness: 기본 저수준 내장 에이전트 런타임 정책입니다. 등록된 Plugin harness가 지원되는 모델을 가져가도록 하려면runtime: "auto"를, 내장 PI harness를 강제하려면runtime: "pi"를, 또는runtime: "codex"처럼 등록된 harness id를 사용하세요. 자동 PI 대체를 비활성화하려면fallback: "none"으로 설정하세요.- 이러한 필드를 변경하는 설정 기록기(예:
/models set,/models set-image, 대체 추가/제거 명령)는 가능하면 정규 객체 형식으로 저장하고 기존 대체 목록을 보존합니다. maxConcurrent: 세션 전체에서 병렬 에이전트 실행의 최대 수입니다(각 세션은 여전히 직렬화됨). 기본값: 4.
agents.defaults.embeddedHarness
embeddedHarness는 어떤 저수준 실행기가 내장 에이전트 턴을 실행할지 제어합니다.
대부분의 배포에서는 기본값 { runtime: "auto", fallback: "pi" }를 유지하는 것이 좋습니다.
번들된
Codex 앱 서버 harness처럼 신뢰할 수 있는 Plugin이 네이티브 harness를 제공할 때 사용하세요.
runtime:"auto","pi", 또는 등록된 Plugin harness id입니다. 번들된 Codex Plugin은codex를 등록합니다.fallback:"pi"또는"none"입니다."pi"는 선택된 Plugin harness가 없을 때 호환성 대체로 내장 PI harness를 유지합니다."none"은 누락되었거나 지원되지 않는 Plugin harness 선택 시 조용히 PI를 사용하는 대신 실패하게 만듭니다. 선택된 Plugin harness 실패는 항상 직접 표시됩니다.- 환경 변수 재정의:
OPENCLAW_AGENT_RUNTIME=<id|auto|pi>는runtime을 재정의하고,OPENCLAW_AGENT_HARNESS_FALLBACK=none은 해당 프로세스의 PI 대체를 비활성화합니다. - Codex 전용 배포의 경우
model: "openai/gpt-5.5",embeddedHarness.runtime: "codex",embeddedHarness.fallback: "none"으로 설정하세요. - harness 선택은 첫 번째 내장 실행 후 세션 id별로 고정됩니다. 설정/환경 변수 변경은 새 세션 또는 초기화된 세션에만 영향을 주며, 기존 대화록에는 영향을 주지 않습니다. 대화록 기록은 있지만 고정된 값이 없는 레거시 세션은 PI에 고정된 것으로 처리됩니다.
/status는Fast옆에codex같은 비-PI harness id를 표시합니다. - 이는 내장 채팅 harness만 제어합니다. 미디어 생성, 비전, PDF, 음악, 비디오, TTS는 여전히 각 provider/model 설정을 사용합니다.
agents.defaults.models에 모델이 있을 때만 적용됨):
| 별칭 | 모델 |
|---|---|
opus | anthropic/claude-opus-4-6 |
sonnet | anthropic/claude-sonnet-4-6 |
gpt | openai/gpt-5.4 또는 구성된 Codex OAuth GPT-5.5 |
gpt-mini | openai/gpt-5.4-mini |
gpt-nano | openai/gpt-5.4-nano |
gemini | google/gemini-3.1-pro-preview |
gemini-flash | google/gemini-3-flash-preview |
gemini-flash-lite | google/gemini-3.1-flash-lite-preview |
--thinking off를 설정하거나 agents.defaults.models["zai/<model>"].params.thinking을 직접 정의하지 않는 한 자동으로 thinking 모드를 활성화합니다.
Z.AI 모델은 도구 호출 스트리밍을 위해 기본적으로 tool_stream을 활성화합니다. 비활성화하려면 agents.defaults.models["zai/<model>"].params.tool_stream을 false로 설정하세요.
Anthropic Claude 4.6 모델은 명시적인 thinking 수준이 설정되지 않은 경우 기본적으로 adaptive thinking을 사용합니다.
agents.defaults.cliBackends
텍스트 전용 대체 실행(도구 호출 없음)을 위한 선택적 CLI 백엔드입니다. API provider가 실패할 때 백업으로 유용합니다.
- CLI 백엔드는 텍스트 우선이며 도구는 항상 비활성화됩니다.
sessionArg가 설정된 경우 세션을 지원합니다.imageArg가 파일 경로를 받으면 이미지 전달을 지원합니다.
agents.defaults.systemPromptOverride
OpenClaw가 조립한 전체 시스템 프롬프트를 고정 문자열로 교체합니다. 기본 수준(agents.defaults.systemPromptOverride) 또는 에이전트별(agents.list[].systemPromptOverride)로 설정할 수 있습니다. 에이전트별 값이 우선하며, 비어 있거나 공백만 있는 값은 무시됩니다. 제어된 프롬프트 실험에 유용합니다.
agents.defaults.promptOverlays
모델 패밀리별로 적용되는 provider 독립적인 프롬프트 오버레이입니다. GPT-5 패밀리 모델 id는 provider 전반에 걸친 공용 동작 계약을 받으며, personality는 친근한 상호작용 스타일 계층만 제어합니다.
"friendly"(기본값)와"on"은 친근한 상호작용 스타일 계층을 활성화합니다."off"는 친근한 계층만 비활성화하며, 태그가 붙은 GPT-5 동작 계약은 계속 활성화됩니다.- 레거시
plugins.entries.openai.config.personality는 이 공용 설정이 없을 때 여전히 읽습니다.
agents.defaults.heartbeat
주기적인 Heartbeat 실행입니다.
every: 기간 문자열(ms/s/m/h)입니다. 기본값:30m(API 키 인증) 또는1h(OAuth 인증). 비활성화하려면0m으로 설정하세요.includeSystemPromptSection: false이면 시스템 프롬프트에서 Heartbeat 섹션을 생략하고 부트스트랩 컨텍스트에HEARTBEAT.md를 주입하지 않습니다. 기본값:true.suppressToolErrorWarnings: true이면 Heartbeat 실행 중 도구 오류 경고 payload를 숨깁니다.timeoutSeconds: 중단되기 전까지 Heartbeat 에이전트 턴에 허용되는 최대 시간(초)입니다. 설정하지 않으면agents.defaults.timeoutSeconds를 사용합니다.directPolicy: direct/DM 전달 정책입니다.allow(기본값)는 direct 대상 전달을 허용합니다.block은 direct 대상 전달을 막고reason=dm-blocked를 발생시킵니다.lightContext: true이면 Heartbeat 실행은 경량 부트스트랩 컨텍스트를 사용하고 워크스페이스 부트스트랩 파일 중HEARTBEAT.md만 유지합니다.isolatedSession: true이면 각 Heartbeat는 이전 대화 기록이 없는 새 세션에서 실행됩니다. CronsessionTarget: "isolated"와 같은 격리 패턴입니다. Heartbeat당 토큰 비용을 약 100K에서 약 2-5K 토큰으로 줄입니다.- 에이전트별:
agents.list[].heartbeat를 설정합니다. 어떤 에이전트든heartbeat를 정의하면 해당 에이전트들만 Heartbeat를 실행합니다. - Heartbeat는 전체 에이전트 턴을 실행하므로 간격이 짧을수록 더 많은 토큰을 소모합니다.
agents.defaults.compaction
mode:default또는safeguard(긴 기록용 청크 단위 요약). Compaction을 참조하세요.provider: 등록된 Compaction provider Plugin의 id입니다. 설정하면 내장 LLM 요약 대신 provider의summarize()가 호출됩니다. 실패 시 내장 방식으로 대체합니다. provider를 설정하면 강제로mode: "safeguard"가 적용됩니다. Compaction을 참조하세요.timeoutSeconds: OpenClaw가 중단하기 전까지 단일 Compaction 작업에 허용되는 최대 시간(초)입니다. 기본값:900.identifierPolicy:strict(기본값),off, 또는custom.strict는 Compaction 요약 중 내장된 불투명 식별자 보존 지침을 앞에 붙입니다.identifierInstructions:identifierPolicy=custom일 때 사용되는 선택적 사용자 정의 식별자 보존 텍스트입니다.postCompactionSections: Compaction 후 다시 주입할 선택적 AGENTS.md H2/H3 섹션 이름입니다. 기본값은["Session Startup", "Red Lines"]이며, 재주입을 비활성화하려면[]로 설정하세요. 설정하지 않았거나 명시적으로 이 기본 쌍으로 설정한 경우, 레거시 대체값으로 오래된Every Session/Safety제목도 허용됩니다.model: Compaction 요약 전용 선택적provider/model-id재정의입니다. 메인 세션은 한 모델을 유지하되 Compaction 요약은 다른 모델에서 실행하려는 경우 사용합니다. 설정하지 않으면 Compaction은 세션의 기본 모델을 사용합니다.notifyUser:true이면 Compaction 시작 및 완료 시 사용자에게 짧은 알림을 보냅니다(예: “Compacting context…”, “Compaction complete”). 기본적으로는 Compaction을 조용히 유지하기 위해 비활성화되어 있습니다.memoryFlush: 자동 Compaction 전에 내구성 있는 메모리를 저장하는 조용한 에이전트 턴입니다. 워크스페이스가 읽기 전용이면 건너뜁니다.
agents.defaults.contextPruning
LLM에 보내기 전에 메모리 내 컨텍스트에서 오래된 도구 결과를 정리합니다. 디스크의 세션 기록은 수정하지 않습니다.
cache-ttl 모드 동작
cache-ttl 모드 동작
mode: "cache-ttl"은 정리 패스를 활성화합니다.ttl은 마지막 캐시 터치 이후 언제 다시 정리를 실행할 수 있는지 제어합니다.- 정리는 먼저 큰 도구 결과를 소프트 트림하고, 필요하면 더 오래된 도구 결과를 하드 클리어합니다.
...를 삽입합니다.하드 클리어는 전체 도구 결과를 placeholder로 대체합니다.참고:- 이미지 블록은 절대 트림/클리어되지 않습니다.
- 비율은 정확한 토큰 수가 아니라 문자 수 기준(대략적)입니다.
keepLastAssistants보다 적은 assistant 메시지만 있으면 정리는 건너뜁니다.
블록 스트리밍
- Telegram이 아닌 채널은 블록 답장을 활성화하려면 명시적으로
*.blockStreaming: true가 필요합니다. - 채널 재정의:
channels.<channel>.blockStreamingCoalesce(및 계정별 변형). Signal/Slack/Discord/Google Chat은 기본값minChars: 1500. humanDelay: 블록 답장 사이의 무작위 지연입니다.natural= 800–2500ms. 에이전트별 재정의:agents.list[].humanDelay.
타이핑 표시기
- 기본값: direct 채팅/멘션은
instant, 멘션되지 않은 그룹 채팅은message. - 세션별 재정의:
session.typingMode,session.typingIntervalSeconds.
agents.defaults.sandbox
내장 에이전트를 위한 선택적 샌드박싱입니다. 전체 가이드는 Sandboxing을 참조하세요.
샌드박스 세부 사항
샌드박스 세부 사항
sandbox.docker.binds는 Docker 전용입니다.
이미지 빌드:
agents.list (에이전트별 재정의)
id: 안정적인 에이전트 id(필수)default: 여러 개가 설정되면 첫 번째가 우선합니다(경고 로그 기록). 아무것도 설정되지 않으면 목록의 첫 번째 항목이 기본값입니다.model: 문자열 형식은primary만 재정의하고, 객체 형식{ primary, fallbacks }는 둘 다 재정의합니다([]는 전역 대체를 비활성화).primary만 재정의하는 Cron 작업은fallbacks: []를 설정하지 않는 한 여전히 기본 대체를 상속합니다.params:agents.defaults.models의 선택된 모델 항목 위에 병합되는 에이전트별 스트림 매개변수입니다. 전체 모델 카탈로그를 복제하지 않고cacheRetention,temperature,maxTokens같은 에이전트별 재정의에 사용하세요.skills: 선택적 에이전트별 Skills 허용 목록입니다. 생략하면 설정된 경우 에이전트는agents.defaults.skills를 상속합니다. 명시적인 목록은 기본값과 병합하지 않고 대체하며,[]는 Skills 없음이라는 뜻입니다.thinkingDefault: 선택적 에이전트별 기본 thinking 수준(off | minimal | low | medium | high | xhigh | adaptive | max)입니다. 메시지별 또는 세션별 재정의가 설정되지 않았을 때 이 에이전트에 대해agents.defaults.thinkingDefault를 재정의합니다.reasoningDefault: 선택적 에이전트별 기본 reasoning 가시성(on | off | stream)입니다. 메시지별 또는 세션별 reasoning 재정의가 없을 때 적용됩니다.fastModeDefault: fast 모드의 선택적 에이전트별 기본값(true | false)입니다. 메시지별 또는 세션별 fast 모드 재정의가 없을 때 적용됩니다.embeddedHarness: 선택적 에이전트별 저수준 harness 정책 재정의입니다.{ runtime: "codex", fallback: "none" }를 사용하면 한 에이전트만 Codex 전용으로 만들고 다른 에이전트는 기본 PI 대체를 유지할 수 있습니다.runtime: 선택적 에이전트별 런타임 설명자입니다. 에이전트가 기본적으로 ACP harness 세션을 사용해야 한다면type: "acp"와 함께runtime.acp기본값(agent,backend,mode,cwd)을 사용하세요.identity.avatar: 워크스페이스 상대 경로,http(s)URL, 또는data:URIidentity는 기본값을 파생합니다:emoji에서ackReaction,name/emoji에서mentionPatternssubagents.allowAgents:sessions_spawn용 에이전트 id 허용 목록(["*"]= 아무거나, 기본값: 같은 에이전트만)- 샌드박스 상속 가드: 요청자 세션이 샌드박스 상태이면
sessions_spawn은 샌드박스 없이 실행될 대상을 거부합니다. subagents.requireAgentId: true이면agentId를 생략한sessions_spawn호출을 차단합니다(명시적 프로필 선택 강제, 기본값: false).
다중 에이전트 라우팅
하나의 Gateway 안에서 여러 격리된 에이전트를 실행합니다. Multi-Agent를 참조하세요.바인딩 match 필드
type(선택 사항): 일반 라우팅에는route(type이 없으면 기본적으로 route), 지속적 ACP 대화 바인딩에는acpmatch.channel(필수)match.accountId(선택 사항,*= 모든 계정, 생략 = 기본 계정)match.peer(선택 사항,{ kind: direct|group|channel, id })match.guildId/match.teamId(선택 사항, 채널별)acp(선택 사항,type: "acp"전용):{ mode, label, cwd, backend }
match.peermatch.guildIdmatch.teamIdmatch.accountId(정확 일치, peer/guild/team 없음)match.accountId: "*"(채널 전체)- 기본 에이전트
bindings 항목이 우선합니다.
type: "acp" 항목의 경우 OpenClaw는 정확한 대화 정체성(match.channel + account + match.peer.id)으로 확인하며 위의 route 바인딩 계층 순서를 사용하지 않습니다.
에이전트별 접근 프로필
전체 접근(샌드박스 없음)
전체 접근(샌드박스 없음)
읽기 전용 도구 + 워크스페이스
읽기 전용 도구 + 워크스페이스
파일시스템 접근 없음(메시징 전용)
파일시스템 접근 없음(메시징 전용)
세션
세션 필드 세부 사항
세션 필드 세부 사항
scope: 그룹 채팅 컨텍스트를 위한 기본 세션 그룹화 전략입니다.per-sender(기본값): 채널 컨텍스트 안에서 각 발신자가 격리된 세션을 가집니다.global: 채널 컨텍스트의 모든 참가자가 하나의 세션을 공유합니다(공유 컨텍스트가 의도된 경우에만 사용).
dmScope: DM을 어떻게 그룹화할지 지정합니다.main: 모든 DM이 메인 세션을 공유합니다.per-peer: 채널 전반에서 발신자 id별로 격리합니다.per-channel-peer: 채널 + 발신자별로 격리합니다(다중 사용자 받은편지함에 권장).per-account-channel-peer: 계정 + 채널 + 발신자별로 격리합니다(다중 계정에 권장).
identityLinks: 채널 간 세션 공유를 위해 정규 id를 provider 접두사가 붙은 peer에 매핑합니다.reset: 기본 초기화 정책입니다.daily는 로컬 시간atHour에 초기화하고,idle은idleMinutes후 초기화합니다. 둘 다 구성된 경우 먼저 만료되는 쪽이 적용됩니다.resetByType: 유형별 재정의(direct,group,thread)입니다. 레거시dm은direct의 별칭으로 허용됩니다.parentForkMaxTokens: 포크된 스레드 세션을 만들 때 허용되는 최대 부모 세션totalTokens값입니다(기본값100000).- 부모
totalTokens가 이 값을 넘으면 OpenClaw는 부모 대화록 기록을 상속하는 대신 새 스레드 세션을 시작합니다. - 이 가드를 비활성화하고 항상 부모 포크를 허용하려면
0으로 설정하세요.
- 부모
mainKey: 레거시 필드입니다. 런타임은 메인 direct-chat 버킷에 항상"main"을 사용합니다.agentToAgent.maxPingPongTurns: 에이전트 간 교환 중 에이전트 간 응답 왕복의 최대 턴 수입니다(정수, 범위:0–5).0은 ping-pong 체이닝을 비활성화합니다.sendPolicy:channel,chatType(direct|group|channel, 레거시dm별칭 포함),keyPrefix,rawKeyPrefix로 match합니다. 첫 번째 deny가 우선합니다.maintenance: 세션 저장소 정리 + 보존 제어입니다.mode:warn은 경고만 발생시키고,enforce는 정리를 적용합니다.pruneAfter: 오래된 항목의 보존 기간 기준선입니다(기본값30d).maxEntries:sessions.json의 최대 항목 수입니다(기본값500).rotateBytes:sessions.json이 이 크기를 넘으면 회전합니다(기본값10mb).resetArchiveRetention:*.reset.<timestamp>대화록 아카이브의 보존 기간입니다. 기본값은pruneAfter이며, 비활성화하려면false로 설정하세요.maxDiskBytes: 선택적 세션 디렉터리 디스크 예산입니다.warn모드에서는 경고를 기록하고,enforce모드에서는 가장 오래된 아티팩트/세션부터 제거합니다.highWaterBytes: 예산 정리 후 목표치입니다. 기본값은maxDiskBytes의80%입니다.
threadBindings: 스레드 바인딩 세션 기능의 전역 기본값입니다.enabled: 마스터 기본 스위치(provider가 재정의 가능, Discord는channels.discord.threadBindings.enabled사용)idleHours: 기본 비활성 자동 unfocus 시간(시간 단위,0이면 비활성화, provider가 재정의 가능)maxAgeHours: 기본 하드 최대 유지 시간(시간 단위,0이면 비활성화, provider가 재정의 가능)
메시지
응답 접두사
채널/계정별 재정의:channels.<channel>.responsePrefix, channels.<channel>.accounts.<id>.responsePrefix.
확인 순서(가장 구체적인 항목 우선): account → channel → global. ""는 비활성화하고 상위 단계 확인도 중단합니다. "auto"는 [{identity.name}]에서 파생됩니다.
템플릿 변수:
| 변수 | 설명 | 예시 |
|---|---|---|
{model} | 짧은 모델 이름 | claude-opus-4-6 |
{modelFull} | 전체 모델 식별자 | anthropic/claude-opus-4-6 |
{provider} | Provider 이름 | anthropic |
{thinkingLevel} | 현재 thinking 수준 | high, low, off |
{identity.name} | 에이전트 정체성 이름 | ("auto"와 동일) |
{think}는 {thinkingLevel}의 별칭입니다.
확인 반응
- 기본값은 활성 에이전트의
identity.emoji, 없으면"👀"입니다. 비활성화하려면""를 설정하세요. - 채널별 재정의:
channels.<channel>.ackReaction,channels.<channel>.accounts.<id>.ackReaction. - 확인 순서: account → channel →
messages.ackReaction→ identity 대체값. - 범위:
group-mentions(기본값),group-all,direct,all. removeAckAfterReply: Slack, Discord, Telegram에서 응답 후 ack를 제거합니다.messages.statusReactions.enabled: Slack, Discord, Telegram에서 수명 주기 상태 반응을 활성화합니다. Slack과 Discord에서는 설정하지 않으면 ack 반응이 활성화된 경우 상태 반응도 활성 상태로 유지됩니다. Telegram에서는 수명 주기 상태 반응을 활성화하려면 이를 명시적으로true로 설정하세요.
인바운드 debounce
같은 발신자의 빠른 텍스트 전용 메시지를 하나의 에이전트 턴으로 묶습니다. 미디어/첨부 파일은 즉시 플러시됩니다. 제어 명령은 debounce를 우회합니다.TTS (text-to-speech)
auto는 기본 자동 TTS 모드를 제어합니다:off,always,inbound,tagged./tts on|off는 로컬 기본 설정을 재정의할 수 있고,/tts status는 유효 상태를 표시합니다.summaryModel은 자동 요약용으로agents.defaults.model.primary를 재정의합니다.modelOverrides는 기본적으로 활성화되어 있으며,modelOverrides.allowProvider의 기본값은false(명시적 활성화 필요)입니다.- API 키는
ELEVENLABS_API_KEY/XI_API_KEY및OPENAI_API_KEY로 대체될 수 있습니다. openai.baseUrl은 OpenAI TTS 엔드포인트를 재정의합니다. 확인 순서는 설정, 그다음OPENAI_TTS_BASE_URL, 마지막으로https://api.openai.com/v1입니다.openai.baseUrl이 OpenAI가 아닌 엔드포인트를 가리키면 OpenClaw는 이를 OpenAI 호환 TTS 서버로 간주하고 모델/음성 검증을 완화합니다.
Talk
Talk 모드(macOS/iOS/Android)의 기본값입니다.talk.provider는 여러 Talk provider가 구성된 경우talk.providers의 키와 일치해야 합니다.- 레거시 평면 Talk 키(
talk.voiceId,talk.voiceAliases,talk.modelId,talk.outputFormat,talk.apiKey)는 호환성 전용이며 자동으로talk.providers.<provider>로 마이그레이션됩니다. - 음성 ID는
ELEVENLABS_VOICE_ID또는SAG_VOICE_ID로 대체됩니다. providers.*.apiKey는 일반 텍스트 문자열 또는 SecretRef 객체를 받을 수 있습니다.- Talk API 키가 구성되지 않았을 때만
ELEVENLABS_API_KEY대체값이 적용됩니다. providers.*.voiceAliases는 Talk 지시문에서 친숙한 이름을 사용할 수 있게 합니다.silenceTimeoutMs는 사용자가 침묵한 뒤 Talk 모드가 대화록을 전송하기까지 기다리는 시간을 제어합니다. 설정하지 않으면 플랫폼 기본 일시 정지 창을 유지합니다(macOS 및 Android는700 ms, iOS는900 ms).
관련 항목
- Configuration reference — 기타 모든 설정 키
- Configuration — 일반 작업 및 빠른 설정
- Configuration examples