실제 환경 설정(로컬 개발, VPS, 멀티 에이전트, OAuth/API 키, 모델 장애 조치)을 위한 빠른 답변과 더 깊은 문제 해결 방법입니다. 런타임 진단은 문제 해결을 참고하세요. 전체 설정 참조는 설정을 참고하세요.Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
문제가 생겼을 때 처음 60초
-
빠른 상태 확인(첫 확인)
빠른 로컬 요약: OS + 업데이트, Gateway/서비스 도달 가능 여부, 에이전트/세션, 제공자 설정 + 런타임 문제(Gateway에 도달할 수 있는 경우).
-
붙여넣을 수 있는 보고서(공유해도 안전)
로그 꼬리를 포함한 읽기 전용 진단(토큰은 수정됨).
-
Daemon + 포트 상태
supervisor 런타임과 RPC 도달 가능 여부, probe 대상 URL, 서비스가 사용했을 가능성이 높은 설정을 보여줍니다.
-
심층 probe
지원되는 경우 채널 probe를 포함해 실시간 Gateway 상태 probe를 실행합니다 (도달 가능한 Gateway가 필요). Health를 참고하세요.
-
최신 로그 따라가기
RPC가 중단된 경우 다음으로 대체하세요.파일 로그는 서비스 로그와 별개입니다. Logging 및 문제 해결을 참고하세요.
-
doctor 실행(복구)
설정/상태를 복구/마이그레이션하고 상태 검사를 실행합니다. Doctor를 참고하세요.
-
Gateway 스냅샷
실행 중인 Gateway에 전체 스냅샷을 요청합니다(WS 전용). Health를 참고하세요.
빠른 시작 및 최초 실행 설정
최초 실행 Q&A(설치, 온보딩, 인증 경로, 구독, 초기 실패)는 최초 실행 FAQ에 있습니다.OpenClaw란 무엇인가요?
OpenClaw를 한 문단으로 설명하면 무엇인가요?
OpenClaw를 한 문단으로 설명하면 무엇인가요?
가치 제안
가치 제안
- 사용자의 장치, 사용자의 데이터: 원하는 곳(Mac, Linux, VPS)에서 Gateway를 실행하고 워크스페이스 + 세션 기록을 로컬에 보관하세요.
- 웹 샌드박스가 아닌 실제 채널: WhatsApp/Telegram/Slack/Discord/Signal/iMessage 등, 지원되는 플랫폼의 모바일 음성 및 Canvas까지 제공합니다.
- 모델에 구애받지 않음: 에이전트별 라우팅과 장애 조치를 통해 Anthropic, OpenAI, MiniMax, OpenRouter 등을 사용할 수 있습니다.
- 로컬 전용 옵션: 원한다면 로컬 모델을 실행해 모든 데이터를 장치에 유지할 수 있습니다.
- 멀티 에이전트 라우팅: 채널, 계정 또는 작업별로 에이전트를 분리하고, 각 에이전트에 고유한 워크스페이스와 기본값을 둘 수 있습니다.
- 오픈 소스이며 해킹 가능: 벤더 종속 없이 검사하고, 확장하고, 직접 호스팅할 수 있습니다.
방금 설정했습니다. 먼저 무엇을 해야 하나요?
방금 설정했습니다. 먼저 무엇을 해야 하나요?
- 웹사이트를 빌드합니다(WordPress, Shopify 또는 간단한 정적 사이트).
- 모바일 앱을 프로토타입으로 만듭니다(개요, 화면, API 계획).
- 파일과 폴더를 정리합니다(정리, 이름 지정, 태그 지정).
- Gmail을 연결하고 요약 또는 후속 조치를 자동화합니다.
OpenClaw의 일상적인 상위 다섯 가지 사용 사례는 무엇인가요?
OpenClaw의 일상적인 상위 다섯 가지 사용 사례는 무엇인가요?
- 개인 브리핑: 받은편지함, 캘린더, 관심 있는 뉴스 요약.
- 조사 및 초안 작성: 이메일 또는 문서를 위한 빠른 조사, 요약, 첫 초안.
- 리마인더 및 후속 조치: Cron 또는 Heartbeat 기반 알림과 체크리스트.
- 브라우저 자동화: 양식 채우기, 데이터 수집, 웹 작업 반복.
- 장치 간 조정: 휴대폰에서 작업을 보내고, Gateway가 서버에서 실행하게 한 뒤, 결과를 채팅으로 돌려받습니다.
OpenClaw가 SaaS의 리드 생성, 아웃리치, 광고, 블로그에 도움이 될 수 있나요?
OpenClaw가 SaaS의 리드 생성, 아웃리치, 광고, 블로그에 도움이 될 수 있나요?
웹 개발에서 Claude Code 대비 장점은 무엇인가요?
웹 개발에서 Claude Code 대비 장점은 무엇인가요?
- 세션 전반에 걸친 영구 메모리 + 워크스페이스
- 다중 플랫폼 접근(WhatsApp, Telegram, TUI, WebChat)
- 도구 오케스트레이션(브라우저, 파일, 예약, 훅)
- 상시 실행 Gateway(VPS에서 실행하고 어디서나 상호작용)
- 로컬 브라우저/화면/카메라/실행을 위한 Node
Skills 및 자동화
저장소를 더럽히지 않고 Skills를 사용자 지정하려면 어떻게 하나요?
저장소를 더럽히지 않고 Skills를 사용자 지정하려면 어떻게 하나요?
~/.openclaw/skills/<name>/SKILL.md에 넣거나 ~/.openclaw/openclaw.json의 skills.load.extraDirs를 통해 폴더를 추가하세요. 우선순위는 <workspace>/skills → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → 번들 → skills.load.extraDirs이므로, 관리형 재정의는 git을 건드리지 않고도 번들 Skills보다 우선합니다. Skill을 전역으로 설치해야 하지만 일부 에이전트에만 보이게 하려면 공유 사본을 ~/.openclaw/skills에 두고 agents.defaults.skills와 agents.list[].skills로 표시 여부를 제어하세요. 업스트림에 반영할 가치가 있는 편집만 저장소에 두고 PR로 제출해야 합니다.사용자 지정 폴더에서 Skills를 로드할 수 있나요?
사용자 지정 폴더에서 Skills를 로드할 수 있나요?
~/.openclaw/openclaw.json의 skills.load.extraDirs로 추가 디렉터리를 넣으세요(가장 낮은 우선순위). 기본 우선순위는 <workspace>/skills → <workspace>/.agents/skills → ~/.agents/skills → ~/.openclaw/skills → 번들 → skills.load.extraDirs입니다. clawhub는 기본적으로 ./skills에 설치하며, OpenClaw는 다음 세션에서 이를 <workspace>/skills로 취급합니다. 해당 Skill이 특정 에이전트에만 보여야 한다면 agents.defaults.skills 또는 agents.list[].skills와 함께 사용하세요.작업별로 다른 모델을 사용하려면 어떻게 하나요?
작업별로 다른 모델을 사용하려면 어떻게 하나요?
- Cron 작업: 격리된 작업은 작업별로
model재정의를 설정할 수 있습니다. - 하위 에이전트: 작업을 기본 모델이 다른 별도 에이전트로 라우팅합니다.
- 온디맨드 전환: 언제든지
/model을 사용해 현재 세션 모델을 전환합니다.
무거운 작업을 하는 동안 봇이 멈춥니다. 이를 어떻게 오프로딩하나요?
무거운 작업을 하는 동안 봇이 멈춥니다. 이를 어떻게 오프로딩하나요?
/subagents를 사용하세요.
채팅에서 /status를 사용하면 Gateway가 지금 무엇을 하고 있는지(그리고 바쁜지 여부)를 볼 수 있습니다.토큰 팁: 긴 작업과 하위 에이전트는 모두 토큰을 소비합니다. 비용이 걱정된다면
agents.defaults.subagents.model을 통해 하위 에이전트에 더 저렴한 모델을 설정하세요.문서: 하위 에이전트, 백그라운드 작업.Discord에서 스레드에 바인딩된 하위 에이전트 세션은 어떻게 작동하나요?
Discord에서 스레드에 바인딩된 하위 에이전트 세션은 어떻게 작동하나요?
thread: true와 함께sessions_spawn을 사용해 생성합니다(지속적인 후속 처리를 위해 선택적으로mode: "session"사용).- 또는
/focus <target>으로 수동 바인딩합니다. /agents를 사용해 바인딩 상태를 확인합니다.- 자동 포커스 해제를 제어하려면
/session idle <duration|off>및/session max-age <duration|off>를 사용합니다. - 스레드를 분리하려면
/unfocus를 사용합니다.
- 전역 기본값:
session.threadBindings.enabled,session.threadBindings.idleHours,session.threadBindings.maxAgeHours. - Discord 재정의:
channels.discord.threadBindings.enabled,channels.discord.threadBindings.idleHours,channels.discord.threadBindings.maxAgeHours. - 생성 시 자동 바인딩:
channels.discord.threadBindings.spawnSessions의 기본값은true입니다. 스레드 바인딩 세션 생성을 비활성화하려면false로 설정하세요.
하위 에이전트가 완료되었지만 완료 업데이트가 잘못된 위치로 갔거나 게시되지 않았습니다. 무엇을 확인해야 하나요?
하위 에이전트가 완료되었지만 완료 업데이트가 잘못된 위치로 갔거나 게시되지 않았습니다. 무엇을 확인해야 하나요?
- 완료 모드 하위 에이전트 전달은 바인딩된 스레드나 대화 라우트가 있으면 이를 우선합니다.
- 완료 출처에 채널만 있는 경우 OpenClaw는 요청자 세션에 저장된 라우트(
lastChannel/lastTo/lastAccountId)로 폴백하므로 직접 전달이 여전히 성공할 수 있습니다. - 바인딩된 라우트도 사용 가능한 저장 라우트도 없으면 직접 전달이 실패할 수 있으며, 결과는 채팅에 즉시 게시되는 대신 대기열에 들어간 세션 전달로 폴백합니다.
- 유효하지 않거나 오래된 대상은 여전히 대기열 폴백 또는 최종 전달 실패를 강제할 수 있습니다.
- 하위 항목의 마지막으로 보이는 어시스턴트 답장이 정확한 무음 토큰
NO_REPLY/no_reply이거나 정확히ANNOUNCE_SKIP이면, OpenClaw는 오래된 이전 진행 상황을 게시하는 대신 의도적으로 알림을 억제합니다. - 하위 항목이 도구 호출만 수행한 뒤 시간 초과되면, 알림은 원시 도구 출력을 재생하는 대신 이를 짧은 부분 진행 요약으로 축약할 수 있습니다.
Cron 또는 알림이 실행되지 않습니다. 무엇을 확인해야 하나요?
Cron 또는 알림이 실행되지 않습니다. 무엇을 확인해야 하나요?
Cron이 실행되었지만 채널로 아무것도 전송되지 않았습니다. 왜 그런가요?
Cron이 실행되었지만 채널로 아무것도 전송되지 않았습니다. 왜 그런가요?
--no-deliver/delivery.mode: "none"은 runner fallback 전송이 예상되지 않음을 의미합니다.- announce 대상(
channel/to)이 없거나 유효하지 않으면 runner가 outbound delivery를 건너뛰었다는 뜻입니다. - 채널 인증 실패(
unauthorized,Forbidden)는 runner가 전달을 시도했지만 자격 증명 때문에 차단되었다는 뜻입니다. - 조용한 격리 결과(
NO_REPLY/no_reply만 있음)는 의도적으로 전달할 수 없는 것으로 처리되므로 runner도 대기 중인 fallback delivery를 억제합니다.
message
도구로 직접 전송할 수 있습니다. --announce는 agent가 아직 보내지 않은 최종 텍스트에 대한 runner
fallback 경로만 제어합니다.디버그:격리된 Cron 실행이 왜 모델을 전환하거나 한 번 재시도했나요?
격리된 Cron 실행이 왜 모델을 전환하거나 한 번 재시도했나요?
LiveSessionModelSwitchError가 발생하면 runtime 모델 handoff를 유지하고 재시도할 수 있습니다. 재시도는 전환된
provider/model을 유지하며, 전환에 새 인증 프로필 override가 포함되어 있으면 Cron은 재시도 전에 그것도 유지합니다.관련 선택 규칙:- 적용 가능한 경우 Gmail hook 모델 override가 먼저 우선합니다.
- 그다음 작업별
model. - 그다음 저장된 Cron 세션 모델 override.
- 그다음 일반 agent/default 모델 선택.
Linux에서 Skills를 어떻게 설치하나요?
Linux에서 Skills를 어떻게 설치하나요?
openclaw skills 명령을 사용하거나 Skills를 workspace에 넣으세요. macOS Skills UI는 Linux에서 사용할 수 없습니다.
https://clawhub.ai에서 Skills를 찾아볼 수 있습니다.openclaw skills install은 활성 workspace의 skills/
디렉터리에 씁니다. 자신의 Skills를 게시하거나 동기화하려는 경우에만 별도의 clawhub CLI를 설치하세요. agent 간 공유 설치의 경우 Skill을
~/.openclaw/skills 아래에 두고, 어떤 agent가 볼 수 있는지 좁히려면
agents.defaults.skills 또는
agents.list[].skills를 사용하세요.OpenClaw가 일정에 따라 또는 백그라운드에서 지속적으로 작업을 실행할 수 있나요?
OpenClaw가 일정에 따라 또는 백그라운드에서 지속적으로 작업을 실행할 수 있나요?
Linux에서 Apple macOS 전용 Skills를 실행할 수 있나요?
Linux에서 Apple macOS 전용 Skills를 실행할 수 있나요?
metadata.openclaw.os와 필수 바이너리로 제한되며, Skills는 Gateway host에서 적격할 때만 system prompt에 표시됩니다. Linux에서는 gating을 override하지 않는 한 darwin 전용 Skills(예: apple-notes, apple-reminders, things-mac)가 로드되지 않습니다.지원되는 패턴은 세 가지입니다.옵션 A - Mac에서 Gateway 실행(가장 간단).
macOS 바이너리가 있는 곳에서 Gateway를 실행한 다음, Linux에서 원격 모드 또는 Tailscale을 통해 연결하세요. Gateway host가 macOS이므로 Skills가 정상적으로 로드됩니다.옵션 B - macOS Node 사용(SSH 없음).
Linux에서 Gateway를 실행하고, macOS Node(메뉴 막대 앱)를 페어링한 뒤 Mac에서 Node Run Commands를 “Always Ask” 또는 “Always Allow”로 설정하세요. 필수 바이너리가 Node에 있으면 OpenClaw는 macOS 전용 Skills를 적격한 것으로 처리할 수 있습니다. agent는 nodes 도구를 통해 해당 Skills를 실행합니다. “Always Ask”를 선택한 경우 prompt에서 “Always Allow”를 승인하면 해당 명령이 allowlist에 추가됩니다.옵션 C - SSH로 macOS 바이너리 프록시(고급).
Gateway는 Linux에 두되, 필수 CLI 바이너리가 Mac에서 실행되는 SSH wrapper로 해석되게 하세요. 그런 다음 Skill을 override하여 Linux를 허용하면 적격 상태가 유지됩니다.-
바이너리용 SSH wrapper를 만듭니다(예: Apple Notes용
memo). -
Linux host의
PATH에 wrapper를 둡니다(예:~/bin/memo). -
Linux를 허용하도록 Skill metadata(workspace 또는
~/.openclaw/skills)를 override합니다. - Skills snapshot이 새로고침되도록 새 session을 시작합니다.
Notion 또는 HeyGen integration이 있나요?
Notion 또는 HeyGen integration이 있나요?
- Custom skill / Plugin: 안정적인 API 접근에 가장 좋습니다(Notion/HeyGen 모두 API가 있음).
- 브라우저 자동화: 코드 없이 작동하지만 더 느리고 취약합니다.
- 클라이언트마다 Notion 페이지 하나(context + preferences + active work).
- session 시작 시 agent에게 해당 페이지를 가져오도록 요청합니다.
skills/ 디렉터리에 들어갑니다. agent 간 공유 Skills의 경우 ~/.openclaw/skills/<name>/SKILL.md에 배치하세요. 일부 agent만 공유 설치를 볼 수 있어야 한다면 agents.defaults.skills 또는 agents.list[].skills를 구성하세요. 일부 Skills는 Homebrew를 통해 설치된 바이너리를 기대합니다. Linux에서는 Linuxbrew를 의미합니다(위 Homebrew Linux FAQ 항목 참조). Skills, Skills 구성, ClawHub을 참고하세요.기존에 로그인된 Chrome을 OpenClaw에서 어떻게 사용하나요?
기존에 로그인된 Chrome을 OpenClaw에서 어떻게 사용하나요?
user 브라우저 프로필을 사용하세요.existing-session / user의 현재 제한:- 작업은 CSS selector 기반이 아니라 ref 기반입니다.
- 업로드에는
ref/inputRef가 필요하며 현재 한 번에 파일 하나를 지원합니다. responsebody, PDF export, download interception, batch actions에는 여전히 managed browser 또는 raw CDP profile이 필요합니다.
Sandboxing 및 memory
전용 sandboxing 문서가 있나요?
전용 sandboxing 문서가 있나요?
Docker가 제한적으로 느껴집니다. 전체 기능을 어떻게 활성화하나요?
Docker가 제한적으로 느껴집니다. 전체 기능을 어떻게 활성화하나요?
node 사용자로 실행되므로 system package, Homebrew 또는 bundled browser를
포함하지 않습니다. 더 완전한 설정을 위해서는 다음을 수행하세요.- cache가 유지되도록
OPENCLAW_HOME_VOLUME로/home/node를 지속화합니다. OPENCLAW_DOCKER_APT_PACKAGES로 system deps를 image에 bake합니다.- bundled CLI를 통해 Playwright browser를 설치합니다.
node /app/node_modules/playwright-core/cli.js install chromium PLAYWRIGHT_BROWSERS_PATH를 설정하고 경로가 지속화되는지 확인합니다.
하나의 agent로 DM은 개인용으로 유지하고 그룹은 공개/sandboxed로 만들 수 있나요?
하나의 agent로 DM은 개인용으로 유지하고 그룹은 공개/sandboxed로 만들 수 있나요?
agents.defaults.sandbox.mode: "non-main"을 사용하면 group/channel session(non-main keys)은 구성된 sandbox backend에서 실행되고, main DM session은 host에서 유지됩니다. backend를 선택하지 않으면 Docker가 기본입니다. 그런 다음 tools.sandbox.tools를 통해 sandboxed session에서 사용할 수 있는 도구를 제한하세요.설정 walkthrough + 예시 config: 그룹: 개인 DMs + 공개 그룹주요 config reference: Gateway 구성host folder를 sandbox에 어떻게 bind하나요?
host folder를 sandbox에 어떻게 bind하나요?
agents.defaults.sandbox.docker.binds를 ["host:path:mode"]로 설정하세요(예: "/home/user/src:/src:ro"). Global + per-agent bind는 병합됩니다. scope: "shared"일 때는 per-agent bind가 무시됩니다. 민감한 항목에는 :ro를 사용하고, bind는 sandbox filesystem wall을 우회한다는 점을 기억하세요.OpenClaw는 정규화된 경로와 가장 깊은 기존 ancestor를 통해 해석된 canonical path 모두에 대해 bind source를 검증합니다. 즉, 마지막 path segment가 아직 존재하지 않아도 symlink-parent escape는 계속 fail closed되며, symlink resolution 후에도 allowed-root check가 계속 적용됩니다.예시와 안전 참고 사항은 Sandboxing 및 Sandbox vs Tool Policy vs Elevated를 참고하세요.memory는 어떻게 작동하나요?
memory는 어떻게 작동하나요?
memory/YYYY-MM-DD.md의 일일 notesMEMORY.md의 curated long-term notes(main/private session 전용)
memory가 계속 잊어버립니다. 어떻게 고정하나요?
memory가 계속 잊어버립니다. 어떻게 고정하나요?
MEMORY.md에,
short-term context는 memory/YYYY-MM-DD.md에 둡니다.이는 아직 개선 중인 영역입니다. model에게 memories를 저장하라고 상기시키면 도움이 됩니다.
model은 무엇을 해야 하는지 알 것입니다. 계속 잊어버린다면 Gateway가 모든 실행에서 같은
workspace를 사용하는지 확인하세요.문서: Memory, Agent workspace.memory는 영원히 유지되나요? 제한은 무엇인가요?
memory는 영원히 유지되나요? 제한은 무엇인가요?
의미 기반 메모리 검색에 OpenAI API 키가 필요한가요?
의미 기반 메모리 검색에 OpenAI API 키가 필요한가요?
OPENAI_API_KEY 또는 models.providers.openai.apiKey)가 필요합니다.제공자를 명시적으로 설정하지 않으면 OpenClaw는 API 키(인증 프로필,
models.providers.*.apiKey 또는 환경 변수)를 확인할 수 있을 때 제공자를 자동으로 선택합니다.
OpenAI 키가 확인되면 OpenAI를 우선 사용하고, 그렇지 않으면 Gemini 키가
확인될 때 Gemini, 그다음 Voyage, 그다음 Mistral을 사용합니다. 원격 키가 없으면 메모리
검색은 구성할 때까지 비활성화된 상태로 유지됩니다. 로컬 모델 경로가
구성되어 있고 존재하면 OpenClaw는
local을 우선 사용합니다. Ollama는
memorySearch.provider = "ollama"를 명시적으로 설정할 때 지원됩니다.로컬로 유지하고 싶다면 memorySearch.provider = "local"을 설정하세요(선택적으로
memorySearch.fallback = "none"도 설정). Gemini 임베딩을 원한다면
memorySearch.provider = "gemini"를 설정하고 GEMINI_API_KEY(또는
memorySearch.remote.apiKey)를 제공하세요. OpenAI, Gemini, Voyage, Mistral, Ollama 또는 local 임베딩
모델을 지원합니다. 설정 세부 정보는 메모리를 참조하세요.항목이 디스크에 저장되는 위치
OpenClaw와 함께 사용하는 모든 데이터가 로컬에 저장되나요?
OpenClaw와 함께 사용하는 모든 데이터가 로컬에 저장되나요?
- 기본적으로 로컬: 세션, 메모리 파일, 구성, 워크스페이스는 Gateway 호스트에 있습니다
(
~/.openclaw+ 사용자의 워크스페이스 디렉터리). - 필요에 따라 원격: 모델 제공자(Anthropic/OpenAI 등)에 보내는 메시지는 해당 API로 전송되고, 채팅 플랫폼(WhatsApp/Telegram/Slack 등)은 메시지 데이터를 해당 서버에 저장합니다.
- 사용자가 범위를 제어: 로컬 모델을 사용하면 프롬프트가 사용자의 머신에 남지만, 채널 트래픽은 여전히 채널 서버를 거칩니다.
OpenClaw는 데이터를 어디에 저장하나요?
OpenClaw는 데이터를 어디에 저장하나요?
$OPENCLAW_STATE_DIR 아래에 저장됩니다(기본값: ~/.openclaw).| 경로 | 목적 |
|---|---|
$OPENCLAW_STATE_DIR/openclaw.json | 기본 구성(JSON5) |
$OPENCLAW_STATE_DIR/credentials/oauth.json | 레거시 OAuth 가져오기(처음 사용할 때 인증 프로필로 복사됨) |
$OPENCLAW_STATE_DIR/agents/<agentId>/agent/auth-profiles.json | 인증 프로필(OAuth, API 키, 선택적 keyRef/tokenRef) |
$OPENCLAW_STATE_DIR/secrets.json | file SecretRef 제공자를 위한 선택적 파일 기반 비밀 페이로드 |
$OPENCLAW_STATE_DIR/agents/<agentId>/agent/auth.json | 레거시 호환성 파일(정적 api_key 항목은 제거됨) |
$OPENCLAW_STATE_DIR/credentials/ | 제공자 상태(예: whatsapp/<accountId>/creds.json) |
$OPENCLAW_STATE_DIR/agents/ | 에이전트별 상태(agentDir + 세션) |
$OPENCLAW_STATE_DIR/agents/<agentId>/sessions/ | 대화 기록 및 상태(에이전트별) |
$OPENCLAW_STATE_DIR/agents/<agentId>/sessions/sessions.json | 세션 메타데이터(에이전트별) |
~/.openclaw/agent/*(openclaw doctor로 마이그레이션됨).워크스페이스(AGENTS.md, 메모리 파일, skills 등)는 별도로 관리되며 agents.defaults.workspace를 통해 구성됩니다(기본값: ~/.openclaw/workspace).AGENTS.md / SOUL.md / USER.md / MEMORY.md는 어디에 있어야 하나요?
AGENTS.md / SOUL.md / USER.md / MEMORY.md는 어디에 있어야 하나요?
~/.openclaw가 아니라 에이전트 워크스페이스에 있습니다.- 워크스페이스(에이전트별):
AGENTS.md,SOUL.md,IDENTITY.md,USER.md,MEMORY.md,memory/YYYY-MM-DD.md, 선택적HEARTBEAT.md. 소문자 루트memory.md는 레거시 복구 입력으로만 사용됩니다. 두 파일이 모두 존재할 때openclaw doctor --fix가 이를MEMORY.md로 병합할 수 있습니다. - 상태 디렉터리(
~/.openclaw): 구성, 채널/제공자 상태, 인증 프로필, 세션, 로그, 공유 skills(~/.openclaw/skills).
~/.openclaw/workspace이며, 다음으로 구성할 수 있습니다.권장 백업 전략
권장 백업 전략
~/.openclaw 아래의 어떤 항목(자격 증명, 세션, 토큰 또는 암호화된 비밀 페이로드)도 커밋하지 마세요.
전체 복원이 필요하다면 워크스페이스와 상태 디렉터리를
별도로 모두 백업하세요(위의 마이그레이션 질문 참조).문서: 에이전트 워크스페이스.OpenClaw를 완전히 제거하려면 어떻게 해야 하나요?
OpenClaw를 완전히 제거하려면 어떻게 해야 하나요?
에이전트가 워크스페이스 밖에서 작업할 수 있나요?
에이전트가 워크스페이스 밖에서 작업할 수 있나요?
agents.defaults.sandbox 또는 에이전트별 샌드박스 설정을 사용하세요. 저장소를
기본 작업 디렉터리로 만들고 싶다면 해당 에이전트의
workspace가 저장소 루트를 가리키도록 하세요. OpenClaw 저장소는 단지 소스 코드입니다. 에이전트가 그 안에서 작업하기를 의도한 경우가 아니라면
워크스페이스는 별도로 유지하세요.예시(저장소를 기본 cwd로 사용):원격 모드: 세션 저장소는 어디에 있나요?
원격 모드: 세션 저장소는 어디에 있나요?
구성 기본 사항
구성 형식은 무엇인가요? 어디에 있나요?
구성 형식은 무엇인가요? 어디에 있나요?
$OPENCLAW_CONFIG_PATH에서 선택적 JSON5 구성을 읽습니다(기본값: ~/.openclaw/openclaw.json).~/.openclaw/workspace의 기본 워크스페이스 포함)을 사용합니다.gateway.bind: "lan"(또는 "tailnet")을 설정했는데 아무것도 수신하지 않거나 UI에 권한 없음이라고 표시됩니다
gateway.bind: "lan"(또는 "tailnet")을 설정했는데 아무것도 수신하지 않거나 UI에 권한 없음이라고 표시됩니다
- 공유 비밀 인증: 토큰 또는 비밀번호
- 올바르게 구성된 ID 인식 리버스 프록시 뒤의
gateway.auth.mode: "trusted-proxy"
gateway.remote.token/.password는 그 자체로 로컬 gateway 인증을 활성화하지 않습니다.- 로컬 호출 경로는
gateway.auth.*가 설정되지 않은 경우에만gateway.remote.*를 대체 수단으로 사용할 수 있습니다. - 비밀번호 인증의 경우 대신
gateway.auth.mode: "password"와gateway.auth.password(또는OPENCLAW_GATEWAY_PASSWORD)를 설정하세요. gateway.auth.token/gateway.auth.password가 SecretRef를 통해 명시적으로 구성되었지만 확인되지 않으면, 확인은 닫힌 방식으로 실패합니다(원격 대체가 이를 가리지 않음).- 공유 비밀 Control UI 설정은
connect.params.auth.token또는connect.params.auth.password(앱/UI 설정에 저장됨)로 인증합니다. Tailscale Serve 또는trusted-proxy와 같은 ID 포함 모드는 대신 요청 헤더를 사용합니다. 공유 비밀을 URL에 넣지 마세요. gateway.auth.mode: "trusted-proxy"에서는 같은 호스트의 루프백 리버스 프록시에 명시적인gateway.auth.trustedProxy.allowLoopback = true와gateway.trustedProxies의 루프백 항목이 필요합니다.
이제 localhost에서 토큰이 필요한 이유는 무엇인가요?
이제 localhost에서 토큰이 필요한 이유는 무엇인가요?
gateway.auth.token, gateway.auth.password, OPENCLAW_GATEWAY_TOKEN 또는 OPENCLAW_GATEWAY_PASSWORD를 명시적으로 구성하세요. 이는 다른 로컬 프로세스가 Gateway를 호출하지 못하도록 차단합니다.다른 인증 경로를 선호한다면 비밀번호 모드(또는 ID 인식 리버스 프록시의 경우 trusted-proxy)를 명시적으로 선택할 수 있습니다. 루프백을 정말로 열어 두고 싶다면 구성에서 gateway.auth.mode: "none"을 명시적으로 설정하세요. Doctor는 언제든지 토큰을 생성해 줄 수 있습니다: openclaw doctor --generate-gateway-token.구성을 변경한 후 재시작해야 하나요?
구성을 변경한 후 재시작해야 하나요?
gateway.reload.mode: "hybrid"(기본값): 안전한 변경 사항은 즉시 적용하고, 중요한 변경 사항은 재시작hot,restart,off도 지원됩니다
재미있는 CLI 태그라인을 비활성화하려면 어떻게 해야 하나요?
재미있는 CLI 태그라인을 비활성화하려면 어떻게 해야 하나요?
cli.banner.taglineMode를 설정하세요.off: 태그라인 텍스트를 숨기지만 배너 제목/버전 줄은 유지합니다.default: 매번All your chats, one OpenClaw.를 사용합니다.random: 재미있거나 시즌별로 바뀌는 태그라인(기본 동작).- 배너를 전혀 원하지 않으면 env
OPENCLAW_HIDE_BANNER=1을 설정하세요.
웹 검색(및 웹 가져오기)을 활성화하려면 어떻게 해야 하나요?
웹 검색(및 웹 가져오기)을 활성화하려면 어떻게 해야 하나요?
web_fetch는 API 키 없이 작동합니다. web_search는 선택한
제공자에 따라 달라집니다.- Brave, Exa, Firecrawl, Gemini, Grok, Kimi, MiniMax Search, Perplexity, Tavily 같은 API 기반 제공자는 일반적인 API 키 설정이 필요합니다.
- Ollama Web Search는 키가 필요 없지만, 구성된 Ollama 호스트를 사용하며
ollama signin이 필요합니다. - DuckDuckGo는 키가 필요 없지만, 비공식 HTML 기반 통합입니다.
- SearXNG는 키가 필요 없거나 자체 호스팅할 수 있습니다.
SEARXNG_BASE_URL또는plugins.entries.searxng.config.webSearch.baseUrl을 구성하세요.
openclaw configure --section web을 실행하고 제공자를 선택하세요.
환경 변수 대안:- Brave:
BRAVE_API_KEY - Exa:
EXA_API_KEY - Firecrawl:
FIRECRAWL_API_KEY - Gemini:
GEMINI_API_KEY - Grok:
XAI_API_KEY - Kimi:
KIMI_API_KEY또는MOONSHOT_API_KEY - MiniMax Search:
MINIMAX_CODE_PLAN_KEY,MINIMAX_CODING_API_KEY또는MINIMAX_API_KEY - Perplexity:
PERPLEXITY_API_KEY또는OPENROUTER_API_KEY - SearXNG:
SEARXNG_BASE_URL - Tavily:
TAVILY_API_KEY
plugins.entries.<plugin>.config.webSearch.* 아래에 있습니다.
레거시 tools.web.search.* 공급자 경로는 호환성을 위해 아직 임시로 로드되지만, 새 설정에는 사용하지 않아야 합니다.
Firecrawl 웹 가져오기 폴백 설정은 plugins.entries.firecrawl.config.webFetch.* 아래에 있습니다.참고:- 허용 목록을 사용하는 경우
web_search/web_fetch/x_search또는group:web을 추가하세요. web_fetch는 기본적으로 활성화됩니다(명시적으로 비활성화하지 않은 경우).tools.web.fetch.provider를 생략하면 OpenClaw가 사용 가능한 자격 증명에서 준비된 첫 번째 가져오기 폴백 공급자를 자동 감지합니다. 현재 번들 공급자는 Firecrawl입니다.- 데몬은
~/.openclaw/.env(또는 서비스 환경)에서 환경 변수를 읽습니다.
config.apply가 내 설정을 지웠습니다. 어떻게 복구하고 방지할 수 있나요?
config.apply가 내 설정을 지웠습니다. 어떻게 복구하고 방지할 수 있나요?
config.apply는 전체 설정을 교체합니다. 부분 객체를 보내면 나머지는 모두
제거됩니다.현재 OpenClaw는 여러 우발적인 덮어쓰기를 방지합니다.- OpenClaw가 소유한 설정 쓰기는 쓰기 전에 변경 후 전체 설정을 검증합니다.
- 유효하지 않거나 파괴적인 OpenClaw 소유 쓰기는 거부되고
openclaw.json.rejected.*로 저장됩니다. - 직접 편집으로 시작 또는 핫 리로드가 깨지면 Gateway는 닫힌 상태로 실패하거나 리로드를 건너뜁니다.
openclaw.json을 다시 쓰지 않습니다. openclaw doctor --fix가 복구를 담당하며, 거부된 파일을openclaw.json.clobbered.*로 저장하면서 마지막 정상 상태를 복원할 수 있습니다.
openclaw logs --follow에서Invalid config at,Config write rejected:또는config reload skipped (invalid config)를 확인하세요.- 활성 설정 옆에 있는 최신
openclaw.json.clobbered.*또는openclaw.json.rejected.*를 검사하세요. openclaw config validate와openclaw doctor --fix를 실행하세요.- 의도한 키만
openclaw config set또는config.patch로 다시 복사하세요. - 마지막 정상 상태나 거부된 페이로드가 없으면 백업에서 복원하거나
openclaw doctor를 다시 실행하고 채널/모델을 다시 설정하세요. - 예상치 못한 일이었다면 버그를 제출하고 마지막으로 알려진 설정이나 백업을 포함하세요.
- 로컬 코딩 에이전트는 로그나 기록에서 작동하는 설정을 재구성할 수 있는 경우가 많습니다.
- 작은 변경에는
openclaw config set을 사용하세요. - 대화형 편집에는
openclaw configure를 사용하세요. - 정확한 경로나 필드 형태가 확실하지 않을 때는 먼저
config.schema.lookup을 사용하세요. 이 명령은 얕은 스키마 Node와 드릴다운을 위한 즉시 하위 요약을 반환합니다. - 부분 RPC 편집에는
config.patch를 사용하고,config.apply는 전체 설정 교체에만 사용하세요. - 에이전트 실행에서 소유자 전용
gateway도구를 사용하는 경우에도tools.exec.ask/tools.exec.security에 대한 쓰기는 계속 거부됩니다(동일한 보호된 exec 경로로 정규화되는 레거시tools.bash.*별칭 포함).
기기 전반에서 특화된 워커와 함께 중앙 Gateway를 어떻게 실행하나요?
기기 전반에서 특화된 워커와 함께 중앙 Gateway를 어떻게 실행하나요?
- Gateway(중앙): 채널(Signal/WhatsApp), 라우팅, 세션을 소유합니다.
- Node(기기): Mac/iOS/Android가 주변 기기로 연결되어 로컬 도구(
system.run,canvas,camera)를 노출합니다. - 에이전트(워커): 특별한 역할(예: “Hetzner 운영”, “개인 데이터”)을 위한 별도의 두뇌/작업 공간입니다.
- 하위 에이전트: 병렬 처리가 필요할 때 메인 에이전트에서 백그라운드 작업을 생성합니다.
- TUI: Gateway에 연결하고 에이전트/세션을 전환합니다.
OpenClaw 브라우저를 헤드리스로 실행할 수 있나요?
OpenClaw 브라우저를 헤드리스로 실행할 수 있나요?
false(헤드풀)입니다. 헤드리스는 일부 사이트에서 봇 방지 검사를 트리거할 가능성이 더 높습니다. 브라우저를 참조하세요.헤드리스는 동일한 Chromium 엔진을 사용하며 대부분의 자동화(양식, 클릭, 스크래핑, 로그인)에 작동합니다. 주요 차이점은 다음과 같습니다.- 보이는 브라우저 창이 없습니다(시각적 확인이 필요하면 스크린샷을 사용하세요).
- 일부 사이트는 헤드리스 모드에서 자동화에 더 엄격합니다(CAPTCHA, 봇 방지). 예를 들어 X/Twitter는 헤드리스 세션을 자주 차단합니다.
브라우저 제어에 Brave를 어떻게 사용하나요?
브라우저 제어에 Brave를 어떻게 사용하나요?
browser.executablePath를 Brave 바이너리(또는 Chromium 기반 브라우저)로 설정하고 Gateway를 다시 시작하세요.
전체 설정 예시는 브라우저를 참조하세요.원격 Gateway와 Node
Telegram, Gateway, Node 사이에서 명령은 어떻게 전파되나요?
Telegram, Gateway, Node 사이에서 명령은 어떻게 전파되나요?
node.* → Node → Gateway → TelegramNode는 들어오는 공급자 트래픽을 보지 않습니다. Node RPC 호출만 수신합니다.Gateway가 원격에 호스팅된 경우 에이전트가 내 컴퓨터에 어떻게 접근할 수 있나요?
Gateway가 원격에 호스팅된 경우 에이전트가 내 컴퓨터에 어떻게 접근할 수 있나요?
node.* 도구(화면, 카메라, 시스템)를 호출할 수 있습니다.일반적인 설정:- 항상 켜져 있는 호스트(VPS/홈 서버)에서 Gateway를 실행합니다.
- Gateway 호스트와 컴퓨터를 같은 tailnet에 둡니다.
- Gateway WS에 접근할 수 있는지 확인합니다(tailnet 바인드 또는 SSH 터널).
- macOS 앱을 로컬에서 열고 SSH를 통한 원격 모드(또는 직접 tailnet)로 연결하여 Node로 등록할 수 있게 합니다.
-
Gateway에서 Node를 승인합니다.
system.run을 허용합니다. 신뢰하는
기기만 페어링하고 보안을 검토하세요.문서: Node, Gateway 프로토콜, macOS 원격 모드, 보안.Tailscale이 연결되어 있지만 응답이 없습니다. 이제 어떻게 해야 하나요?
Tailscale이 연결되어 있지만 응답이 없습니다. 이제 어떻게 해야 하나요?
- Gateway가 실행 중인지:
openclaw gateway status - Gateway 상태:
openclaw status - 채널 상태:
openclaw channels status
- Tailscale Serve를 사용하는 경우
gateway.auth.allowTailscale이 올바르게 설정되어 있는지 확인하세요. - SSH 터널로 연결하는 경우 로컬 터널이 실행 중이고 올바른 포트를 가리키는지 확인하세요.
- 허용 목록(DM 또는 그룹)에 계정이 포함되어 있는지 확인하세요.
두 OpenClaw 인스턴스가 서로 통신할 수 있나요(로컬 + VPS)?
두 OpenClaw 인스턴스가 서로 통신할 수 있나요(로컬 + VPS)?
openclaw agent --message ... --deliver로 다른 Gateway를 호출하는 스크립트를 실행하세요.
한 봇이 원격 VPS에 있다면 SSH/Tailscale을 통해 CLI가 해당 원격 Gateway를 가리키게 하세요
(원격 액세스 참조).예시 패턴(대상 Gateway에 접근할 수 있는 머신에서 실행):여러 에이전트에 별도 VPS가 필요한가요?
여러 에이전트에 별도 VPS가 필요한가요?
VPS에서 SSH를 사용하는 대신 개인 노트북에서 Node를 사용하는 이점이 있나요?
VPS에서 SSH를 사용하는 대신 개인 노트북에서 Node를 사용하는 이점이 있나요?
- 인바운드 SSH가 필요 없습니다. Node는 Gateway WebSocket으로 아웃바운드 연결하고 기기 페어링을 사용합니다.
- 더 안전한 실행 제어.
system.run은 해당 노트북의 Node 허용 목록/승인으로 제한됩니다. - 더 많은 기기 도구. Node는
system.run외에도canvas,camera,screen을 노출합니다. - 로컬 브라우저 자동화. Gateway는 VPS에 두고, 노트북의 Node 호스트를 통해 Chrome을 로컬에서 실행하거나 Chrome MCP를 통해 호스트의 로컬 Chrome에 연결하세요.
Node가 Gateway 서비스를 실행하나요?
Node가 Gateway 서비스를 실행하나요?
gateway, discovery, 호스팅된 Plugin 표면 변경에는 전체 재시작이 필요합니다.설정을 적용하는 API / RPC 방법이 있나요?
설정을 적용하는 API / RPC 방법이 있나요?
config.schema.lookup: 쓰기 전에 얕은 스키마 노드, 일치한 UI 힌트, 즉시 하위 요약과 함께 구성 하위 트리 하나를 검사합니다config.get: 현재 스냅샷 + 해시를 가져옵니다config.patch: 안전한 부분 업데이트(대부분의 RPC 편집에 권장); 가능하면 핫 리로드하고 필요하면 다시 시작합니다config.apply: 전체 구성을 검증 + 교체합니다; 가능하면 핫 리로드하고 필요하면 다시 시작합니다- 소유자 전용
gateway런타임 도구는 여전히tools.exec.ask/tools.exec.security다시 쓰기를 거부합니다. 레거시tools.bash.*별칭은 동일한 보호된 exec 경로로 정규화됩니다
첫 설치를 위한 최소한의 정상 구성
첫 설치를 위한 최소한의 정상 구성
VPS에 Tailscale을 설정하고 Mac에서 연결하려면 어떻게 해야 하나요?
VPS에 Tailscale을 설정하고 Mac에서 연결하려면 어떻게 해야 하나요?
-
VPS에 설치 + 로그인
-
Mac에 설치 + 로그인
- Tailscale 앱을 사용하고 같은 tailnet에 로그인합니다.
-
MagicDNS 활성화(권장)
- Tailscale 관리자 콘솔에서 MagicDNS를 활성화하여 VPS가 안정적인 이름을 갖도록 합니다.
-
tailnet 호스트 이름 사용
- SSH:
ssh user@your-vps.tailnet-xxxx.ts.net - Gateway WS:
ws://your-vps.tailnet-xxxx.ts.net:18789
- SSH:
Mac 노드를 원격 Gateway(Tailscale Serve)에 연결하려면 어떻게 해야 하나요?
Mac 노드를 원격 Gateway(Tailscale Serve)에 연결하려면 어떻게 해야 하나요?
- VPS + Mac이 같은 tailnet에 있는지 확인합니다.
- Remote 모드에서 macOS 앱을 사용합니다(SSH 대상은 tailnet 호스트 이름일 수 있음). 앱이 Gateway 포트를 터널링하고 노드로 연결됩니다.
-
gateway에서 노드를 승인합니다.
두 번째 노트북에 설치해야 하나요, 아니면 노드를 추가하기만 하면 되나요?
두 번째 노트북에 설치해야 하나요, 아니면 노드를 추가하기만 하면 되나요?
환경 변수 및 .env 로드
OpenClaw는 환경 변수를 어떻게 로드하나요?
OpenClaw는 환경 변수를 어떻게 로드하나요?
- 현재 작업 디렉터리의
.env ~/.openclaw/.env의 전역 폴백.env(일명$OPENCLAW_STATE_DIR/.env)
.env 파일도 기존 환경 변수를 덮어쓰지 않습니다.구성에서 인라인 환경 변수를 정의할 수도 있습니다(프로세스 환경에 없을 때만 적용됨).서비스를 통해 Gateway를 시작했더니 환경 변수가 사라졌습니다. 이제 어떻게 해야 하나요?
서비스를 통해 Gateway를 시작했더니 환경 변수가 사라졌습니다. 이제 어떻게 해야 하나요?
- 누락된 키를
~/.openclaw/.env에 넣어 서비스가 shell 환경을 상속하지 않아도 선택되도록 합니다. - shell 가져오기를 활성화합니다(옵트인 편의 기능).
OPENCLAW_LOAD_SHELL_ENV=1, OPENCLAW_SHELL_ENV_TIMEOUT_MS=15000.COPILOT_GITHUB_TOKEN을 설정했지만 models status에 "Shell env: off."가 표시됩니다. 왜 그런가요?
COPILOT_GITHUB_TOKEN을 설정했지만 models status에 "Shell env: off."가 표시됩니다. 왜 그런가요?
openclaw models status는 shell 환경 가져오기가 활성화되어 있는지 보고합니다. “Shell env: off”는
환경 변수가 없다는 뜻이 아닙니다. OpenClaw가 로그인 shell을
자동으로 로드하지 않는다는 뜻일 뿐입니다.Gateway가 서비스(launchd/systemd)로 실행되면 shell
환경을 상속하지 않습니다. 다음 중 하나로 해결하세요.-
토큰을
~/.openclaw/.env에 넣습니다. -
또는 shell 가져오기를 활성화합니다(
env.shellEnv.enabled: true). -
또는 구성의
env블록에 추가합니다(없을 때만 적용됨).
COPILOT_GITHUB_TOKEN에서 읽습니다(GH_TOKEN / GITHUB_TOKEN도 포함).
/concepts/model-providers 및 /environment를 참조하세요.세션 및 여러 채팅
새 대화를 시작하려면 어떻게 해야 하나요?
새 대화를 시작하려면 어떻게 해야 하나요?
/new 또는 /reset을 보내세요. 세션 관리를 참조하세요./new를 보내지 않으면 세션이 자동으로 재설정되나요?
/new를 보내지 않으면 세션이 자동으로 재설정되나요?
session.idleMinutes 이후 만료될 수 있지만, 이는 기본적으로 비활성화되어 있습니다(기본값 0).
유휴 만료를 활성화하려면 양수 값으로 설정하세요. 활성화되면 유휴 기간 이후의 다음
메시지가 해당 채팅 키에 대한 새 세션 ID를 시작합니다.
이는 transcript를 삭제하지 않으며, 새 세션을 시작할 뿐입니다.OpenClaw 인스턴스 팀(CEO 한 명과 여러 에이전트)을 만들 방법이 있나요?
OpenClaw 인스턴스 팀(CEO 한 명과 여러 에이전트)을 만들 방법이 있나요?
작업 중간에 컨텍스트가 잘린 이유는 무엇인가요? 어떻게 방지하나요?
작업 중간에 컨텍스트가 잘린 이유는 무엇인가요? 어떻게 방지하나요?
- 봇에게 현재 상태를 요약하고 파일에 쓰도록 요청합니다.
- 긴 작업 전에는
/compact를 사용하고, 주제를 전환할 때는/new를 사용합니다. - 중요한 컨텍스트는 작업 공간에 보관하고 봇에게 다시 읽도록 요청합니다.
- 긴 작업이나 병렬 작업에는 하위 에이전트를 사용하여 메인 채팅을 더 작게 유지합니다.
- 이런 일이 자주 발생하면 더 큰 컨텍스트 창을 가진 모델을 선택합니다.
OpenClaw를 설치된 상태로 유지하면서 완전히 재설정하려면 어떻게 해야 하나요?
OpenClaw를 설치된 상태로 유지하면서 완전히 재설정하려면 어떻게 해야 하나요?
- 기존 구성이 보이면 온보딩도 Reset을 제공합니다. 온보딩(CLI)을 참조하세요.
- 프로필(
--profile/OPENCLAW_PROFILE)을 사용했다면 각 상태 디렉터리를 재설정하세요(기본값은~/.openclaw-<profile>). - 개발 재설정:
openclaw gateway --dev --reset(개발 전용; 개발 구성 + 자격 증명 + 세션 + 작업 공간 삭제).
"context too large" 오류가 발생합니다. 어떻게 재설정하거나 압축하나요?
"context too large" 오류가 발생합니다. 어떻게 재설정하거나 압축하나요?
-
Compaction(대화를 유지하지만 오래된 턴을 요약):
또는 요약을 안내하려면
/compact <instructions>를 사용합니다. -
재설정(같은 채팅 키에 대한 새 세션 ID):
- 세션 가지치기(
agents.defaults.contextPruning)를 활성화하거나 조정하여 오래된 도구 출력을 다듬습니다. - 더 큰 컨텍스트 창을 가진 모델을 사용합니다.
"LLM request rejected: messages.content.tool_use.input field required"가 표시되는 이유는 무엇인가요?
"LLM request rejected: messages.content.tool_use.input field required"가 표시되는 이유는 무엇인가요?
input 없이 tool_use 블록을 내보냈다는 뜻입니다.
보통 세션 기록이 오래되었거나 손상되었음을 의미합니다(긴 스레드
또는 도구/스키마 변경 이후에 자주 발생).해결: /new(독립 메시지)로 새 세션을 시작합니다.왜 30분마다 Heartbeat 메시지를 받나요?
왜 30분마다 Heartbeat 메시지를 받나요?
HEARTBEAT.md가 존재하지만 사실상 비어 있는 경우(빈 줄과 # Heading 같은 markdown
헤더만 있는 경우), OpenClaw는 API 호출을 절약하기 위해 heartbeat 실행을 건너뜁니다.
파일이 없으면 heartbeat는 계속 실행되고 모델이 수행할 작업을 결정합니다.에이전트별 재정의에는 agents.list[].heartbeat를 사용합니다. 문서: Heartbeat.WhatsApp 그룹에 "bot account"를 추가해야 하나요?
WhatsApp 그룹에 "bot account"를 추가해야 하나요?
groupPolicy: "allowlist").사용자만 그룹 답장을 트리거할 수 있게 하려면 다음과 같이 설정하세요.WhatsApp 그룹의 JID는 어떻게 얻나요?
WhatsApp 그룹의 JID는 어떻게 얻나요?
OpenClaw가 그룹에서 답장하지 않는 이유는 무엇인가요?
OpenClaw가 그룹에서 답장하지 않는 이유는 무엇인가요?
그룹/스레드는 DM과 컨텍스트를 공유하나요?
그룹/스레드는 DM과 컨텍스트를 공유하나요?
워크스페이스와 에이전트는 몇 개까지 만들 수 있나요?
워크스페이스와 에이전트는 몇 개까지 만들 수 있나요?
- 디스크 증가: 세션 + 트랜스크립트는
~/.openclaw/agents/<agentId>/sessions/아래에 있습니다. - 토큰 비용: 에이전트가 많을수록 동시 모델 사용량이 늘어납니다.
- 운영 부담: 에이전트별 인증 프로필, 워크스페이스, 채널 라우팅.
- 에이전트마다 하나의 활성 워크스페이스를 유지하세요(
agents.defaults.workspace). - 디스크가 커지면 오래된 세션을 정리하세요(JSONL 또는 저장소 항목 삭제).
openclaw doctor를 사용해 남은 워크스페이스와 프로필 불일치를 찾으세요.
여러 봇이나 채팅을 동시에 실행할 수 있나요(Slack)? 어떻게 설정해야 하나요?
여러 봇이나 채팅을 동시에 실행할 수 있나요(Slack)? 어떻게 설정해야 하나요?
- 상시 실행 Gateway 호스트(VPS/Mac mini).
- 역할별 에이전트 하나(바인딩).
- 해당 에이전트에 바인딩된 Slack 채널.
- 필요 시 Chrome MCP 또는 노드를 통한 로컬 브라우저.
모델, 장애 조치, 인증 프로필
모델 Q&A — 기본값, 선택, 별칭, 전환, 장애 조치, 인증 프로필 — 는 모델 FAQ에 있습니다.Gateway: 포트, “이미 실행 중”, 원격 모드
Gateway는 어떤 포트를 사용하나요?
Gateway는 어떤 포트를 사용하나요?
gateway.port는 WebSocket + HTTP(Control UI, 훅 등)를 위한 단일 멀티플렉스 포트를 제어합니다.우선순위:왜 openclaw gateway status가 "Runtime: running"이지만 "Connectivity probe: failed"라고 표시하나요?
왜 openclaw gateway status가 "Runtime: running"이지만 "Connectivity probe: failed"라고 표시하나요?
openclaw gateway status를 사용하고 다음 줄을 신뢰하세요.Probe target:(프로브가 실제로 사용한 URL)Listening:(포트에 실제로 바인딩된 대상)Last gateway error:(프로세스는 살아 있지만 포트가 수신 중이 아닐 때의 일반적인 근본 원인)
왜 openclaw gateway status에서 "Config (cli)"와 "Config (service)"가 다르게 표시되나요?
왜 openclaw gateway status에서 "Config (cli)"와 "Config (service)"가 다르게 표시되나요?
--profile / OPENCLAW_STATE_DIR 불일치).해결:--profile / 환경에서 이 명령을 실행하세요."another gateway instance is already listening"은 무슨 뜻인가요?
"another gateway instance is already listening"은 무슨 뜻인가요?
ws://127.0.0.1:18789). 바인딩이 EADDRINUSE로 실패하면 다른 인스턴스가 이미 수신 중임을 나타내는 GatewayLockError를 throw합니다.해결: 다른 인스턴스를 중지하거나, 포트를 비우거나, openclaw gateway --port <port>로 실행하세요.OpenClaw를 원격 모드(클라이언트가 다른 곳의 Gateway에 연결)로 실행하려면 어떻게 하나요?
OpenClaw를 원격 모드(클라이언트가 다른 곳의 Gateway에 연결)로 실행하려면 어떻게 하나요?
gateway.mode: "remote"를 설정하고 원격 WebSocket URL을 지정하세요. 선택적으로 공유 시크릿 원격 자격 증명을 사용할 수 있습니다.openclaw gateway는gateway.mode가local일 때만 시작됩니다(또는 오버라이드 플래그를 전달한 경우).- macOS 앱은 구성 파일을 감시하며 이 값들이 변경되면 실시간으로 모드를 전환합니다.
gateway.remote.token/.password는 클라이언트 측 원격 자격 증명일 뿐이며, 그 자체로 로컬 Gateway 인증을 활성화하지 않습니다.
Control UI에서 "unauthorized"라고 표시됩니다(또는 계속 재연결합니다). 이제 어떻게 해야 하나요?
Control UI에서 "unauthorized"라고 표시됩니다(또는 계속 재연결합니다). 이제 어떻게 해야 하나요?
gateway.bind를 tailnet으로 설정했지만 바인딩할 수 없고 아무것도 수신하지 않습니다
gateway.bind를 tailnet으로 설정했지만 바인딩할 수 없고 아무것도 수신하지 않습니다
tailnet 바인딩은 네트워크 인터페이스(100.64.0.0/10)에서 Tailscale IP를 선택합니다. 머신이 Tailscale에 있지 않거나 인터페이스가 내려가 있으면 바인딩할 대상이 없습니다.해결:- 해당 호스트에서 Tailscale을 시작하거나(100.x 주소를 갖도록), 또는
gateway.bind: "loopback"/"lan"으로 전환하세요.
tailnet은 명시적입니다. auto는 loopback을 선호합니다. tailnet 전용 바인딩을 원할 때는 gateway.bind: "tailnet"을 사용하세요.같은 호스트에서 여러 Gateway를 실행할 수 있나요?
같은 호스트에서 여러 Gateway를 실행할 수 있나요?
OPENCLAW_CONFIG_PATH(인스턴스별 구성)OPENCLAW_STATE_DIR(인스턴스별 상태)agents.defaults.workspace(워크스페이스 격리)gateway.port(고유 포트)
- 인스턴스마다
openclaw --profile <name> ...를 사용하세요(~/.openclaw-<name>자동 생성). - 각 프로필 구성에 고유한
gateway.port를 설정하세요(또는 수동 실행 시--port전달). - 프로필별 서비스를 설치하세요:
openclaw --profile <name> gateway install.
ai.openclaw.<profile>, 레거시 com.openclaw.*, openclaw-gateway-<profile>.service, OpenClaw Gateway (<profile>)).
전체 가이드: 여러 Gateway."invalid handshake" / 코드 1008은 무슨 뜻인가요?
"invalid handshake" / 코드 1008은 무슨 뜻인가요?
connect 프레임이기를 기대합니다. 그 외의 것을 받으면 코드 1008(정책 위반)로
연결을 닫습니다.일반적인 원인:- WS 클라이언트 대신 브라우저에서 HTTP URL(
http://...)을 열었습니다. - 잘못된 포트 또는 경로를 사용했습니다.
- 프록시 또는 터널이 인증 헤더를 제거했거나 Gateway가 아닌 요청을 보냈습니다.
- WS URL을 사용하세요:
ws://<host>:18789(또는 HTTPS이면wss://...). - 일반 브라우저 탭에서 WS 포트를 열지 마세요.
- 인증이 켜져 있다면
connect프레임에 토큰/비밀번호를 포함하세요.
로깅 및 디버깅
로그는 어디에 있나요?
로그는 어디에 있나요?
logging.file을 통해 안정적인 경로를 설정할 수 있습니다. 파일 로그 수준은 logging.level로 제어됩니다. 콘솔 상세도는 --verbose와 logging.consoleLevel로 제어됩니다.가장 빠른 로그 tail:- macOS:
$OPENCLAW_STATE_DIR/logs/gateway.log및gateway.err.log(기본값:~/.openclaw/logs/..., 프로필은~/.openclaw-<profile>/logs/...사용) - Linux:
journalctl --user -u openclaw-gateway[-<profile>].service -n 200 --no-pager - Windows:
schtasks /Query /TN "OpenClaw Gateway (<profile>)" /V /FO LIST
Gateway 서비스를 시작/중지/재시작하려면 어떻게 하나요?
Gateway 서비스를 시작/중지/재시작하려면 어떻게 하나요?
Windows에서 터미널을 닫았습니다. OpenClaw를 어떻게 재시작하나요?
Windows에서 터미널을 닫았습니다. OpenClaw를 어떻게 재시작하나요?
Gateway는 올라와 있지만 응답이 도착하지 않습니다. 무엇을 확인해야 하나요?
Gateway는 올라와 있지만 응답이 도착하지 않습니다. 무엇을 확인해야 하나요?
"Gateway에서 연결 해제됨: 이유 없음" - 이제 어떻게 해야 하나요?
"Gateway에서 연결 해제됨: 이유 없음" - 이제 어떻게 해야 하나요?
Telegram setMyCommands가 실패합니다. 무엇을 확인해야 하나요?
Telegram setMyCommands가 실패합니다. 무엇을 확인해야 하나요?
BOT_COMMANDS_TOO_MUCH: Telegram 메뉴 항목이 너무 많습니다. OpenClaw는 이미 Telegram 제한에 맞게 줄이고 더 적은 명령으로 재시도하지만, 일부 메뉴 항목은 여전히 제거해야 합니다. Plugin/스킬/사용자 지정 명령을 줄이거나, 메뉴가 필요하지 않다면channels.telegram.commands.native를 비활성화하세요.TypeError: fetch failed,Network request for 'setMyCommands' failed!또는 유사한 네트워크 오류: VPS를 사용 중이거나 프록시 뒤에 있다면, 아웃바운드 HTTPS가 허용되고api.telegram.org에 대한 DNS가 작동하는지 확인하세요.
TUI에 출력이 표시되지 않습니다. 무엇을 확인해야 하나요?
TUI에 출력이 표시되지 않습니다. 무엇을 확인해야 하나요?
Gateway를 완전히 중지한 다음 시작하려면 어떻게 하나요?
Gateway를 완전히 중지한 다음 시작하려면 어떻게 하나요?
간단 설명: openclaw gateway restart와 openclaw gateway
간단 설명: openclaw gateway restart와 openclaw gateway
openclaw gateway restart: 백그라운드 서비스(launchd/systemd)를 다시 시작합니다.openclaw gateway: 이 터미널 세션에서 gateway를 포그라운드로 실행합니다.
openclaw gateway를 사용하세요.문제가 발생했을 때 더 자세한 정보를 얻는 가장 빠른 방법
문제가 발생했을 때 더 자세한 정보를 얻는 가장 빠른 방법
--verbose로 Gateway를 시작하세요. 그런 다음 채널 인증, 모델 라우팅, RPC 오류가 있는지 로그 파일을 검사하세요.미디어 및 첨부 파일
내 스킬이 이미지/PDF를 생성했지만 아무것도 전송되지 않았습니다
내 스킬이 이미지/PDF를 생성했지만 아무것도 전송되지 않았습니다
MEDIA:<path-or-url> 줄이 포함되어야 합니다(해당 줄만 단독으로). OpenClaw 어시스턴트 설정 및 에이전트 전송을 참조하세요.CLI 전송:- 대상 채널이 아웃바운드 미디어를 지원하고 허용 목록에 의해 차단되지 않는지 확인하세요.
- 파일이 제공자의 크기 제한 내에 있는지 확인하세요(이미지는 최대 2048px로 크기가 조정됨).
tools.fs.workspaceOnly=true는 로컬 경로 전송을 워크스페이스, 임시/미디어 저장소, 샌드박스에서 검증된 파일로 제한합니다.tools.fs.workspaceOnly=false는MEDIA:가 에이전트가 이미 읽을 수 있는 호스트 로컬 파일을 보내도록 허용하지만, 미디어와 안전한 문서 유형(이미지, 오디오, 비디오, PDF, Office 문서)에만 해당합니다. 일반 텍스트와 비밀처럼 보이는 파일은 여전히 차단됩니다.
보안 및 액세스 제어
인바운드 DM에 OpenClaw를 노출해도 안전한가요?
인바운드 DM에 OpenClaw를 노출해도 안전한가요?
- DM이 가능한 채널의 기본 동작은 페어링입니다.
- 알 수 없는 발신자는 페어링 코드를 받으며, 봇은 해당 메시지를 처리하지 않습니다.
- 다음으로 승인하세요:
openclaw pairing approve --channel <channel> [--account <id>] <code> - 대기 중인 요청은 채널당 3개로 제한됩니다. 코드가 도착하지 않았다면
openclaw pairing list --channel <channel> [--account <id>]를 확인하세요.
- DM을 공개적으로 열려면 명시적인 옵트인이 필요합니다(
dmPolicy: "open"및 허용 목록"*").
openclaw doctor를 실행하세요.프롬프트 인젝션은 공개 봇에서만 문제가 되나요?
프롬프트 인젝션은 공개 봇에서만 문제가 되나요?
- 신뢰할 수 없는 콘텐츠를 요약할 때 읽기 전용 또는 도구 비활성화 “리더” 에이전트 사용
- 도구가 활성화된 에이전트에서는
web_search/web_fetch/browser끄기 - 디코딩된 파일/문서 텍스트도 신뢰할 수 없는 것으로 취급하기: OpenResponses
input_file과 미디어 첨부 추출은 모두 원시 파일 텍스트를 전달하는 대신 추출된 텍스트를 명시적인 외부 콘텐츠 경계 마커로 감쌉니다 - 샌드박스와 엄격한 도구 허용 목록 사용
내 봇에 자체 이메일, GitHub 계정 또는 전화번호가 있어야 하나요?
내 봇에 자체 이메일, GitHub 계정 또는 전화번호가 있어야 하나요?
내 문자 메시지에 대한 자율성을 부여할 수 있으며, 그것이 안전한가요?
내 문자 메시지에 대한 자율성을 부여할 수 있으며, 그것이 안전한가요?
- DM을 페어링 모드 또는 엄격한 허용 목록으로 유지하세요.
- 사용자를 대신해 메시지를 보내게 하려면 별도 번호 또는 계정을 사용하세요.
- 먼저 초안을 작성하게 한 다음 전송 전에 승인하세요.
개인 어시스턴트 작업에 더 저렴한 모델을 사용할 수 있나요?
개인 어시스턴트 작업에 더 저렴한 모델을 사용할 수 있나요?
Telegram에서 /start를 실행했지만 페어링 코드를 받지 못했습니다
Telegram에서 /start를 실행했지만 페어링 코드를 받지 못했습니다
dmPolicy: "pairing"이 활성화되어 있을 때만 전송됩니다. /start 자체는 코드를 생성하지 않습니다.대기 중인 요청 확인:dmPolicy: "open"을 설정하세요.WhatsApp: 내 연락처에 메시지를 보내나요? 페어링은 어떻게 작동하나요?
WhatsApp: 내 연락처에 메시지를 보내나요? 페어링은 어떻게 작동하나요?
channels.whatsapp.selfChatMode를 활성화하세요.채팅 명령, 작업 중단, 그리고 “멈추지 않습니다”
내부 시스템 메시지가 채팅에 표시되지 않게 하려면 어떻게 하나요?
내부 시스템 메시지가 채팅에 표시되지 않게 하려면 어떻게 하나요?
verboseDefault가 on으로 설정된 봇 프로필을 사용 중이 아닌지 확인하세요.문서: 사고 및 verbose, 보안.실행 중인 작업을 중지/취소하려면 어떻게 하나요?
실행 중인 작업을 중지/취소하려면 어떻게 하나요?
/로 시작하는 독립 메시지로 보내야 하지만, 일부 단축 명령(/status 등)은 허용 목록에 있는 발신자에게는 인라인에서도 작동합니다.Telegram에서 Discord 메시지를 보내려면 어떻게 하나요?("크로스 컨텍스트 메시징 거부됨")
Telegram에서 Discord 메시지를 보내려면 어떻게 하나요?("크로스 컨텍스트 메시징 거부됨")
봇이 연속 메시지를 "무시하는" 것처럼 느껴지는 이유는 무엇인가요?
봇이 연속 메시지를 "무시하는" 것처럼 느껴지는 이유는 무엇인가요?
/queue를 사용하세요.steer- 현재 실행의 다음 모델 경계까지 대기 중인 모든 조종을 큐에 넣음queue- 기존의 한 번에 하나씩 조종followup- 메시지를 한 번에 하나씩 실행collect- 메시지를 배치 처리하고 한 번만 답변steer-backlog- 지금 조종한 다음 backlog 처리interrupt- 현재 실행을 중단하고 새로 시작
steer입니다. 후속 모드에는 debounce:0.5s cap:25 drop:summarize 같은 옵션을 추가할 수 있습니다. 명령 큐와 스티어링 큐를 참조하세요.기타
API 키가 있는 Anthropic의 기본 모델은 무엇인가요?
API 키가 있는 Anthropic의 기본 모델은 무엇인가요?
ANTHROPIC_API_KEY를 설정하거나 인증 프로필에 Anthropic API 키를 저장하면 인증이 활성화되지만, 실제 기본 모델은 agents.defaults.model.primary에 구성한 값입니다(예: anthropic/claude-sonnet-4-6 또는 anthropic/claude-opus-4-6). No credentials found for profile "anthropic:default"가 표시되면, 실행 중인 에이전트의 예상 auth-profiles.json에서 Gateway가 Anthropic 자격 증명을 찾지 못했다는 뜻입니다.아직 막혀 있나요? Discord에서 질문하거나 GitHub 토론을 여세요.