Doctor
openclaw doctor는 OpenClaw의 복구 + 마이그레이션 도구입니다. 오래된
config/state를 수정하고, 상태를 점검하며, 실행 가능한 복구 단계를 제공합니다.
빠른 시작
헤드리스 / 자동화
수행 내용(요약)
- git 설치에 대한 선택적 사전 업데이트(대화형 전용).
- UI 프로토콜 최신 상태 점검(프로토콜 스키마가 더 새로우면 Control UI를 다시 빌드).
- 상태 점검 + 재시작 프롬프트.
- Skills 상태 요약(적격/누락/차단) 및 plugin 상태.
- 기존 값에 대한 config 정규화.
- 기존 평면
talk.*필드에서talk.provider+talk.providers.<provider>로의 Talk config 마이그레이션. - 기존 Chrome 확장 프로그램 config 및 Chrome MCP 준비 상태에 대한 브라우저 마이그레이션 점검.
- OpenCode provider 재정의 경고(
models.providers.opencode/models.providers.opencode-go). - Codex OAuth 가림 경고(
models.providers.openai-codex). - OpenAI Codex OAuth 프로필용 OAuth TLS 선행 조건 점검.
- 기존 디스크 상태 마이그레이션(세션/agent 디렉터리/WhatsApp 인증).
- 기존 plugin manifest 계약 키 마이그레이션(
speechProviders,realtimeTranscriptionProviders,realtimeVoiceProviders,mediaUnderstandingProviders,imageGenerationProviders,videoGenerationProviders,webFetchProviders,webSearchProviders→contracts). - 기존 cron 저장소 마이그레이션(
jobId,schedule.cron, 최상위 delivery/payload 필드, payloadprovider, 단순notify: truewebhook 대체 작업). - 세션 잠금 파일 검사 및 오래된 잠금 정리.
- 상태 무결성 및 권한 점검(세션, 대화록, 상태 디렉터리).
- 로컬 실행 시 config 파일 권한 점검(chmod 600).
- 모델 인증 상태: OAuth 만료를 점검하고, 만료 예정 토큰을 갱신할 수 있으며, auth-profile cooldown/비활성 상태를 보고합니다.
- 추가 workspace 디렉터리 감지(
~/openclaw). - 샌드박싱이 활성화된 경우 샌드박스 이미지 복구.
- 기존 서비스 마이그레이션 및 추가 gateway 감지.
- Matrix 채널 기존 상태 마이그레이션(
--fix/--repair모드에서). - Gateway 런타임 점검(서비스는 설치되었지만 실행 중이 아님, 캐시된 launchd 레이블).
- 채널 상태 경고(실행 중인 gateway에서 프로브).
- 선택적 복구가 포함된 supervisor config 감사(launchd/systemd/schtasks).
- Gateway 런타임 모범 사례 점검(Node vs Bun, 버전 관리자 경로).
- Gateway 포트 충돌 진단(기본값
18789). - 열린 DM 정책에 대한 보안 경고.
- 로컬 토큰 모드용 gateway 인증 점검(토큰 소스가 없을 때 토큰 생성을 제안하며, 토큰 SecretRef config는 덮어쓰지 않음).
- Linux에서 systemd linger 점검.
- Workspace 부트스트랩 파일 크기 점검(컨텍스트 파일에 대한 잘림/한계 근접 경고).
- 셸 자동 완성 상태 점검 및 자동 설치/업그레이드.
- 메모리 검색 임베딩 provider 준비 상태 점검(로컬 모델, 원격 API 키 또는 QMD 바이너리).
- 소스 설치 점검(pnpm workspace 불일치, 누락된 UI 자산, 누락된 tsx 바이너리).
- 업데이트된 config + wizard 메타데이터 기록.
Dreams UI 백필 및 재설정
Control UI Dreams 장면에는 근거 기반 dreaming 워크플로를 위한 Backfill, Reset, Clear Grounded 작업이 포함됩니다. 이러한 작업은 gateway doctor 스타일 RPC 메서드를 사용하지만,openclaw doctor CLI
복구/마이그레이션의 일부는 아닙니다.
수행하는 작업:
- Backfill은 활성
workspace의 과거
memory/YYYY-MM-DD.md파일을 스캔하고, 근거 기반 REM 일지 패스를 실행하며, 되돌릴 수 있는 백필 항목을DREAMS.md에 기록합니다. - Reset은 표시된 백필 일지 항목만
DREAMS.md에서 제거합니다. - Clear Grounded는 과거 재생에서 온, 아직 실제 recall 또는 일일 지원이 누적되지 않은, 준비된 근거 기반 전용 단기 항목만 제거합니다.
MEMORY.md를 편집하지 않습니다- 전체 doctor 마이그레이션을 실행하지 않습니다
- 먼저 준비 CLI 경로를 명시적으로 실행하지 않는 한, 근거 기반 후보를 실시간 단기 승격 저장소에 자동으로 준비하지 않습니다
DREAMS.md를 검토 표면으로 유지하면서
근거 기반의 오래 유지할 후보를 단기 dreaming 저장소에 준비합니다.
자세한 동작 및 근거
0) 선택적 업데이트(git 설치)
이것이 git 체크아웃이고 doctor가 대화형으로 실행 중이면, doctor 실행 전에 업데이트(fetch/rebase/build)할지 제안합니다.1) Config 정규화
config에 기존 값 형태가 포함되어 있는 경우(예: 채널별 재정의가 없는messages.ackReaction)
doctor는 이를 현재 스키마로 정규화합니다.
여기에는 기존 Talk 평면 필드도 포함됩니다. 현재 공개 Talk config는
talk.provider + talk.providers.<provider>입니다. Doctor는 기존
talk.voiceId / talk.voiceAliases / talk.modelId / talk.outputFormat /
talk.apiKey 형태를 provider 맵으로 다시 작성합니다.
2) 기존 config 키 마이그레이션
config에 더 이상 사용되지 않는 키가 포함되어 있으면, 다른 명령은 실행을 거부하고openclaw doctor를 실행하라고 요청합니다.
Doctor는 다음을 수행합니다.
- 어떤 기존 키가 발견되었는지 설명합니다.
- 적용한 마이그레이션을 보여줍니다.
- 업데이트된 스키마로
~/.openclaw/openclaw.json을 다시 기록합니다.
openclaw doctor --fix가 처리합니다.
현재 마이그레이션:
routing.allowFrom→channels.whatsapp.allowFromrouting.groupChat.requireMention→channels.whatsapp/telegram/imessage.groups."*".requireMentionrouting.groupChat.historyLimit→messages.groupChat.historyLimitrouting.groupChat.mentionPatterns→messages.groupChat.mentionPatternsrouting.queue→messages.queuerouting.bindings→ 최상위bindingsrouting.agents/routing.defaultAgentId→agents.list+agents.list[].default- 기존
talk.voiceId/talk.voiceAliases/talk.modelId/talk.outputFormat/talk.apiKey→talk.provider+talk.providers.<provider> routing.agentToAgent→tools.agentToAgentrouting.transcribeAudio→tools.media.audio.modelsmessages.tts.<provider>(openai/elevenlabs/microsoft/edge) →messages.tts.providers.<provider>channels.discord.voice.tts.<provider>(openai/elevenlabs/microsoft/edge) →channels.discord.voice.tts.providers.<provider>channels.discord.accounts.<id>.voice.tts.<provider>(openai/elevenlabs/microsoft/edge) →channels.discord.accounts.<id>.voice.tts.providers.<provider>plugins.entries.voice-call.config.tts.<provider>(openai/elevenlabs/microsoft/edge) →plugins.entries.voice-call.config.tts.providers.<provider>plugins.entries.voice-call.config.provider: "log"→"mock"plugins.entries.voice-call.config.twilio.from→plugins.entries.voice-call.config.fromNumberplugins.entries.voice-call.config.streaming.sttProvider→plugins.entries.voice-call.config.streaming.providerplugins.entries.voice-call.config.streaming.openaiApiKey|sttModel|silenceDurationMs|vadThreshold→plugins.entries.voice-call.config.streaming.providers.openai.*bindings[].match.accountID→bindings[].match.accountId- 이름 있는
accounts가 있지만 단일 계정용 최상위 채널 값이 남아 있는 채널의 경우, 해당 계정 범위 값을 그 채널에 대해 선택된 승격 대상 계정으로 이동합니다(대부분의 채널은accounts.default; Matrix는 기존에 일치하는 이름 있는/기본 대상을 유지할 수 있음) identity→agents.list[].identityagent.*→agents.defaults+tools.*(tools/elevated/exec/sandbox/subagents)agent.model/allowedModels/modelAliases/modelFallbacks/imageModelFallbacks→agents.defaults.models+agents.defaults.model.primary/fallbacks+agents.defaults.imageModel.primary/fallbacksbrowser.ssrfPolicy.allowPrivateNetwork→browser.ssrfPolicy.dangerouslyAllowPrivateNetworkbrowser.profiles.*.driver: "extension"→"existing-session"browser.relayBindHost제거(기존 확장 프로그램 relay 설정)
channels.<channel>.accounts항목이 둘 이상 구성되어 있는데channels.<channel>.defaultAccount또는accounts.default가 없으면, doctor는 대체 라우팅이 예상치 못한 계정을 선택할 수 있다고 경고합니다.channels.<channel>.defaultAccount가 알 수 없는 계정 ID로 설정되어 있으면, doctor는 경고하고 구성된 계정 ID 목록을 보여줍니다.
2b) OpenCode provider 재정의
models.providers.opencode, opencode-zen, 또는 opencode-go를 수동으로
추가한 경우, @mariozechner/pi-ai의 내장 OpenCode 카탈로그를 재정의하게 됩니다.
이로 인해 모델이 잘못된 API로 강제되거나 비용이 0으로 표시될 수 있습니다. Doctor는
재정의를 제거하고 모델별 API 라우팅 + 비용을 복원할 수 있도록 경고합니다.
2c) 브라우저 마이그레이션 및 Chrome MCP 준비 상태
브라우저 config가 여전히 제거된 Chrome 확장 프로그램 경로를 가리키는 경우, doctor는 이를 현재 호스트 로컬 Chrome MCP 연결 모델로 정규화합니다.browser.profiles.*.driver: "extension"은"existing-session"이 됩니다browser.relayBindHost는 제거됩니다
defaultProfile: "user" 또는 구성된 existing-session 프로필을 사용할 때 호스트 로컬 Chrome MCP 경로를 점검합니다.
- 기본 자동 연결 프로필에 대해 같은 호스트에 Google Chrome이 설치되어 있는지 확인합니다
- 감지된 Chrome 버전을 확인하고 Chrome 144 미만이면 경고합니다
- 브라우저 inspect 페이지에서 원격 디버깅을 활성화하라고 알려줍니다(예:
chrome://inspect/#remote-debugging,brave://inspect/#remote-debugging, 또는edge://inspect/#remote-debugging)
- gateway/node 호스트에 Chromium 기반 브라우저 144+가 있어야 함
- 브라우저가 로컬에서 실행 중이어야 함
- 해당 브라우저에서 원격 디버깅이 활성화되어 있어야 함
- 브라우저에서 최초 연결 동의 프롬프트를 승인해야 함
responsebody, PDF
내보내기, 다운로드 가로채기, 배치 작업과 같은 고급 경로는 여전히 관리형
브라우저 또는 원시 CDP 프로필이 필요합니다.
이 점검은 Docker, 샌드박스, 원격 브라우저 또는 기타
헤드리스 흐름에는 적용되지 않습니다. 이러한 경우는 계속해서 원시 CDP를 사용합니다.
2d) OAuth TLS 선행 조건
OpenAI Codex OAuth 프로필이 구성되어 있으면, doctor는 OpenAI 인증 엔드포인트를 프로브하여 로컬 Node/OpenSSL TLS 스택이 인증서 체인을 검증할 수 있는지 확인합니다. 프로브가 인증서 오류로 실패하면(예:UNABLE_TO_GET_ISSUER_CERT_LOCALLY, 만료된 인증서 또는 자체 서명 인증서),
doctor는 플랫폼별 수정 안내를 출력합니다. Homebrew Node를 사용하는 macOS에서는
보통 brew postinstall ca-certificates로 해결합니다. --deep를 사용하면 gateway가 정상이어도
프로브가 실행됩니다.
2c) Codex OAuth provider 재정의
이전에models.providers.openai-codex 아래에 기존 OpenAI 전송 설정을 추가했다면,
최신 릴리스가 자동으로 사용하는 내장 Codex OAuth
provider 경로를 가릴 수 있습니다. Doctor는 Codex OAuth와 함께 이러한 기존 전송 설정을 발견하면
오래된 전송 재정의를 제거하거나 다시 작성하여 내장 라우팅/대체 동작을
다시 사용할 수 있도록 경고합니다. 사용자 지정 프록시와 헤더 전용 재정의는 여전히 지원되며 이 경고를
발생시키지 않습니다.
3) 기존 상태 마이그레이션(디스크 레이아웃)
Doctor는 오래된 디스크 레이아웃을 현재 구조로 마이그레이션할 수 있습니다.- 세션 저장소 + 대화록:
~/.openclaw/sessions/에서~/.openclaw/agents/<agentId>/sessions/로
- Agent 디렉터리:
~/.openclaw/agent/에서~/.openclaw/agents/<agentId>/agent/로
- WhatsApp 인증 상태(Baileys):
- 기존
~/.openclaw/credentials/*.json(oauth.json제외)에서 ~/.openclaw/credentials/whatsapp/<accountId>/...로(기본 계정 ID:default)
- 기존
openclaw doctor를 통해서만
마이그레이션됩니다. Talk provider/provider-map 정규화는 이제
구조적 동등성으로 비교하므로, 키 순서만 다른 차이로 인해
반복적인 무의미한 doctor --fix 변경이 더 이상 발생하지 않습니다.
3a) 기존 plugin manifest 마이그레이션
Doctor는 설치된 모든 plugin manifest를 검사하여 더 이상 사용되지 않는 최상위 capability 키(speechProviders, realtimeTranscriptionProviders,
realtimeVoiceProviders, mediaUnderstandingProviders,
imageGenerationProviders, videoGenerationProviders, webFetchProviders,
webSearchProviders)를 찾습니다. 발견되면 이를 contracts
객체로 이동하고 manifest 파일을 제자리에서 다시 쓰도록 제안합니다. 이 마이그레이션은 멱등적입니다.
contracts 키에 이미 같은 값이 있으면,
기존 키는 데이터를 중복하지 않고 제거됩니다.
3b) 기존 cron 저장소 마이그레이션
Doctor는 또한 cron 작업 저장소(기본값~/.openclaw/cron/jobs.json,
또는 재정의된 경우 cron.store)에 대해 스케줄러가 호환성을 위해 여전히
허용하는 오래된 작업 형태가 있는지 점검합니다.
현재 cron 정리 항목:
jobId→idschedule.cron→schedule.expr- 최상위 payload 필드(
message,model,thinking, …) →payload - 최상위 delivery 필드(
deliver,channel,to,provider, …) →delivery - payload
providerdelivery 별칭 → 명시적delivery.channel - 단순 기존
notify: truewebhook 대체 작업 → 명시적delivery.mode="webhook"와delivery.to=cron.webhook
notify: true 작업을 자동 마이그레이션합니다.
작업이 기존 notify 대체와 기존의
비-webhook delivery 모드를 함께 사용하는 경우, doctor는 경고하고 해당 작업은 수동 검토용으로 남겨둡니다.
3c) 세션 잠금 정리
Doctor는 모든 agent 세션 디렉터리를 스캔하여 오래된 쓰기 잠금 파일을 찾습니다. 이는 세션이 비정상적으로 종료될 때 남겨진 파일입니다. 발견된 각 잠금 파일에 대해 다음을 보고합니다. 경로, PID, 해당 PID가 아직 살아 있는지, 잠금 경과 시간, 그리고 오래된 것으로 간주되는지 여부(죽은 PID이거나 30분 초과).--fix / --repair
모드에서는 오래된 잠금 파일을 자동으로 제거합니다. 그렇지 않으면 메모를 출력하고
--fix로 다시 실행하라고 안내합니다.
4) 상태 무결성 점검(세션 지속성, 라우팅, 안전성)
상태 디렉터리는 운영의 핵심 기반입니다. 이것이 사라지면 세션, 자격 증명, 로그, config를 잃게 됩니다(다른 곳에 백업이 없는 한). Doctor는 다음을 점검합니다.- 상태 디렉터리 누락: 치명적인 상태 손실을 경고하고, 디렉터리 재생성을 제안하며, 누락된 데이터를 복구할 수 없음을 알려줍니다.
- 상태 디렉터리 권한: 쓰기 가능 여부를 확인하고, 권한 복구를 제안합니다
(소유자/그룹 불일치가 감지되면
chown힌트도 출력). - macOS 클라우드 동기화 상태 디렉터리: 상태가 iCloud Drive
(
~/Library/Mobile Documents/com~apple~CloudDocs/...) 또는~/Library/CloudStorage/...아래로 해석되면 경고합니다. 동기화 기반 경로는 느린 I/O와 잠금/동기화 경쟁을 유발할 수 있기 때문입니다. - Linux SD 또는 eMMC 상태 디렉터리: 상태가
mmcblk*마운트 소스로 해석되면 경고합니다. SD 또는 eMMC 기반 랜덤 I/O는 세션 및 자격 증명 기록에서 더 느리고 마모가 더 빠를 수 있기 때문입니다. - 세션 디렉터리 누락:
sessions/와 세션 저장소 디렉터리는 기록을 유지하고ENOENT충돌을 방지하는 데 필요합니다. - 대화록 불일치: 최근 세션 항목에 누락된 대화록 파일이 있으면 경고합니다.
- 메인 세션 “1줄 JSONL”: 메인 대화록에 한 줄만 있는 경우(기록이 누적되지 않음)를 표시합니다.
- 여러 상태 디렉터리: 여러 홈 디렉터리에
~/.openclaw폴더가 있거나OPENCLAW_STATE_DIR이 다른 곳을 가리키면 경고합니다(기록이 설치 간에 분리될 수 있음). - 원격 모드 알림:
gateway.mode=remote이면 doctor는 원격 호스트에서 실행하라고 알려줍니다(상태는 그곳에 있음). - Config 파일 권한:
~/.openclaw/openclaw.json이 그룹/전체 읽기 가능하면 경고하고600으로 제한할 것을 제안합니다.
5) 모델 인증 상태(OAuth 만료)
Doctor는 인증 저장소의 OAuth 프로필을 검사하고, 토큰이 곧 만료되거나 이미 만료된 경우 경고하며, 안전한 경우 갱신할 수 있습니다. Anthropic OAuth/토큰 프로필이 오래된 경우, Anthropic API 키 또는 Anthropic setup-token 경로를 제안합니다. 갱신 프롬프트는 대화형(TTY)으로 실행할 때만 표시되며,--non-interactive는
갱신 시도를 건너뜁니다.
OAuth 갱신이 영구적으로 실패하면(예: refresh_token_reused,
invalid_grant, 또는 provider가 다시 로그인하라고 알리는 경우),
doctor는 재인증이 필요하다고 보고하고 실행해야 할 정확한
openclaw models auth login --provider ... 명령을 출력합니다.
Doctor는 또한 다음과 같은 이유로 일시적으로 사용할 수 없는 auth profile도 보고합니다.
- 짧은 cooldown(속도 제한/타임아웃/인증 실패)
- 더 긴 비활성화(청구/크레딧 실패)
6) Hooks 모델 검증
hooks.gmail.model이 설정되어 있으면, doctor는 모델 참조를
카탈로그 및 허용 목록과 대조해 검증하고, 해결되지 않거나 허용되지 않으면 경고합니다.
7) 샌드박스 이미지 복구
샌드박싱이 활성화된 경우, doctor는 Docker 이미지를 점검하고 현재 이미지가 없으면 빌드하거나 기존 이름으로 전환할 것을 제안합니다.7b) 번들 plugin 런타임 의존성
Doctor는 번들 plugin 런타임 의존성(예: Discord plugin 런타임 패키지)이 OpenClaw 설치 루트에 존재하는지 확인합니다. 누락된 항목이 있으면 doctor는 해당 패키지를 보고하고openclaw doctor --fix / openclaw doctor --repair 모드에서 설치합니다.
8) Gateway 서비스 마이그레이션 및 정리 힌트
Doctor는 기존 gateway 서비스(launchd/systemd/schtasks)를 감지하고 이를 제거한 뒤 현재 gateway 포트를 사용하는 OpenClaw 서비스를 설치할 것을 제안합니다. 또한 추가 gateway 유사 서비스를 검사하여 정리 힌트를 출력할 수 있습니다. 프로필 이름이 붙은 OpenClaw gateway 서비스는 정식 항목으로 간주되며 “추가”로 표시되지 않습니다.8b) 시작 Matrix 마이그레이션
Matrix 채널 계정에 보류 중이거나 실행 가능한 기존 상태 마이그레이션이 있으면, doctor는(--fix / --repair 모드에서) 마이그레이션 전 스냅샷을 생성한 다음
최선형 마이그레이션 단계를 실행합니다: 기존 Matrix 상태 마이그레이션과 기존
암호화 상태 준비. 두 단계 모두 치명적이지 않으며, 오류는 기록되고
시작은 계속됩니다. 읽기 전용 모드(--fix 없는 openclaw doctor)에서는 이 점검이
완전히 건너뛰어집니다.
9) 보안 경고
Doctor는 provider가 허용 목록 없이 DM에 열려 있거나, 정책이 위험한 방식으로 구성된 경우 경고를 출력합니다.10) systemd linger(Linux)
systemd 사용자 서비스로 실행 중인 경우, doctor는 로그아웃 후에도 gateway가 계속 실행되도록 linger가 활성화되어 있는지 확인합니다.11) Workspace 상태(Skills, plugins, 기존 디렉터리)
Doctor는 기본 agent에 대한 workspace 상태 요약을 출력합니다.- Skills 상태: 적격, 요구 사항 누락, 허용 목록 차단된 skills 수를 집계합니다.
- 기존 workspace 디렉터리: 현재 workspace와 함께
~/openclaw또는 기타 기존 workspace 디렉터리가 존재하면 경고합니다. - Plugin 상태: 로드됨/비활성화됨/오류 plugin 수를 집계하고, 오류가 있는 경우 plugin ID를 나열하며, 번들 plugin capability를 보고합니다.
- Plugin 호환성 경고: 현재 런타임과 호환성 문제가 있는 plugins를 표시합니다.
- Plugin 진단: plugin registry가 로드 시 출력한 경고나 오류를 표시합니다.
11b) 부트스트랩 파일 크기
Doctor는 workspace 부트스트랩 파일(예:AGENTS.md,
CLAUDE.md, 또는 기타 주입된 컨텍스트 파일)이 구성된
문자 예산에 근접했거나 초과했는지 점검합니다. 파일별 원본 문자 수 대 주입 문자 수, 잘림
비율, 잘림 원인(max/file 또는 max/total), 그리고 전체 예산 대비 총 주입
문자 수를 비율로 보고합니다. 파일이 잘렸거나 한계에 근접한 경우,
doctor는 agents.defaults.bootstrapMaxChars
및 agents.defaults.bootstrapTotalMaxChars 조정을 위한 팁을 출력합니다.
11c) 셸 자동 완성
Doctor는 현재 셸에 대해 탭 자동 완성이 설치되어 있는지 점검합니다 (zsh, bash, fish, 또는 PowerShell).- 셸 프로필이 느린 동적 자동 완성 패턴을 사용하는 경우
(
source <(openclaw completion ...)), doctor는 이를 더 빠른 캐시 파일 변형으로 업그레이드합니다. - 프로필에 자동 완성이 구성되어 있지만 캐시 파일이 없으면, doctor는 캐시를 자동으로 다시 생성합니다.
- 자동 완성이 전혀 구성되어 있지 않으면, doctor는 설치를 제안합니다
(대화형 모드에서만,
--non-interactive에서는 건너뜀).
openclaw completion --write-state를 실행하세요.
12) Gateway 인증 점검(로컬 토큰)
Doctor는 로컬 gateway 토큰 인증 준비 상태를 점검합니다.- 토큰 모드에 토큰이 필요하고 토큰 소스가 없으면, doctor는 토큰 생성을 제안합니다.
gateway.auth.token이 SecretRef로 관리되지만 사용할 수 없으면, doctor는 경고하고 평문으로 덮어쓰지 않습니다.openclaw doctor --generate-gateway-token은 토큰 SecretRef가 구성되지 않았을 때만 강제로 생성합니다.
12b) 읽기 전용 SecretRef 인식 복구
일부 복구 흐름은 런타임 fail-fast 동작을 약화시키지 않으면서 구성된 자격 증명을 검사해야 합니다.openclaw doctor --fix는 이제 대상 config 복구를 위해 상태 계열 명령과 동일한 읽기 전용 SecretRef 요약 모델을 사용합니다.- 예: Telegram
allowFrom/groupAllowFrom@username복구는 가능하면 구성된 bot 자격 증명을 사용하려고 시도합니다. - Telegram bot 토큰이 SecretRef를 통해 구성되었지만 현재 명령 경로에서 사용할 수 없으면, doctor는 해당 자격 증명이 구성되었지만 사용할 수 없다고 보고하고, 충돌하거나 토큰이 누락된 것으로 잘못 보고하는 대신 자동 해결을 건너뜁니다.
13) Gateway 상태 점검 + 재시작
Doctor는 상태 점검을 실행하고 gateway가 정상적이지 않아 보이면 재시작을 제안합니다.13b) 메모리 검색 준비 상태
Doctor는 구성된 메모리 검색 임베딩 provider가 기본 agent에 대해 준비되어 있는지 점검합니다. 동작은 구성된 백엔드와 provider에 따라 달라집니다.- QMD 백엔드:
qmd바이너리를 사용할 수 있고 시작 가능한지 프로브합니다. 그렇지 않으면 npm 패키지 및 수동 바이너리 경로 옵션을 포함한 수정 안내를 출력합니다. - 명시적 로컬 provider: 로컬 모델 파일 또는 인식 가능한 원격/다운로드 가능한 모델 URL이 있는지 점검합니다. 없으면 원격 provider로 전환할 것을 제안합니다.
- 명시적 원격 provider (
openai,voyage등): API 키가 환경 변수 또는 인증 저장소에 있는지 확인합니다. 없으면 실행 가능한 수정 힌트를 출력합니다. - 자동 provider: 먼저 로컬 모델 가용성을 점검한 다음, 자동 선택 순서대로 각 원격 provider를 시도합니다.
openclaw memory status --deep를 사용하세요.
14) 채널 상태 경고
gateway가 정상적이면, doctor는 채널 상태 프로브를 실행하고 권장 수정과 함께 경고를 보고합니다.15) Supervisor config 감사 + 복구
Doctor는 설치된 supervisor config(launchd/systemd/schtasks)를 점검하여 누락되었거나 오래된 기본값(예: systemd network-online 의존성 및 재시작 지연)을 찾습니다. 불일치를 발견하면 업데이트를 권장하고 서비스 파일/작업을 현재 기본값으로 다시 쓸 수 있습니다. 참고:openclaw doctor는 supervisor config를 다시 쓰기 전에 프롬프트를 표시합니다.openclaw doctor --yes는 기본 복구 프롬프트를 수락합니다.openclaw doctor --repair는 프롬프트 없이 권장 수정을 적용합니다.openclaw doctor --repair --force는 사용자 지정 supervisor config를 덮어씁니다.- 토큰 인증에 토큰이 필요하고
gateway.auth.token이 SecretRef로 관리되는 경우, doctor 서비스 설치/복구는 SecretRef를 검증하지만 해결된 평문 토큰 값을 supervisor 서비스 환경 메타데이터에 저장하지 않습니다. - 토큰 인증에 토큰이 필요하고 구성된 토큰 SecretRef가 해결되지 않으면, doctor는 실행 가능한 안내와 함께 설치/복구 경로를 차단합니다.
gateway.auth.token과gateway.auth.password가 모두 구성되어 있는데gateway.auth.mode가 설정되지 않으면, doctor는 모드가 명시적으로 설정될 때까지 설치/복구를 차단합니다.- Linux user-systemd 유닛의 경우, doctor 토큰 드리프트 점검은 이제 서비스 인증 메타데이터 비교 시
Environment=와EnvironmentFile=소스를 모두 포함합니다. - 언제든지
openclaw gateway install --force로 전체 다시 쓰기를 강제할 수 있습니다.
16) Gateway 런타임 + 포트 진단
Doctor는 서비스 런타임(PID, 마지막 종료 상태)을 검사하고, 서비스는 설치되었지만 실제로 실행 중이 아닐 때 경고합니다. 또한 gateway 포트(기본값18789)의
포트 충돌을 점검하고 가능한 원인(gateway가 이미 실행 중, SSH 터널)을 보고합니다.
17) Gateway 런타임 모범 사례
Doctor는 gateway 서비스가 Bun 또는 버전 관리형 Node 경로 (nvm, fnm, volta, asdf 등)에서 실행될 때 경고합니다. WhatsApp + Telegram 채널은 Node를 필요로 하며,
버전 관리자 경로는 서비스가 셸 초기화 스크립트를 로드하지 않기 때문에 업그레이드 후 깨질 수 있습니다.
사용 가능한 경우, doctor는 시스템 Node 설치(Homebrew/apt/choco)로 마이그레이션할 것을 제안합니다.