OpenClaw은 여러 소스에서 환경 변수를 가져옵니다. 규칙은 기존 값을 절대 덮어쓰지 않음입니다.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.
우선순위(가장 높음 → 가장 낮음)
- 프로세스 환경(Gateway 프로세스가 이미 부모 셸/데몬에서 받은 값).
- 현재 작업 디렉터리의
.env(dotenv 기본값, 덮어쓰지 않음). - **전역
.env**인~/.openclaw/.env(일명$OPENCLAW_STATE_DIR/.env, 덮어쓰지 않음). ~/.openclaw/openclaw.json의 Configenv블록(누락된 경우에만 적용).- 선택적 로그인 셸 가져오기(
env.shellEnv.enabled또는OPENCLAW_LOAD_SHELL_ENV=1), 예상 키 중 누락된 키에만 적용.
.env 이후의 호환성 폴백으로 ~/.config/openclaw/gateway.env도 처리합니다. 두 파일이 모두 존재하고 서로 다르면 OpenClaw은 ~/.openclaw/.env를 유지하고 경고를 출력합니다.
Config 파일이 아예 없으면 4단계는 건너뜁니다. 셸 가져오기는 활성화된 경우 계속 실행됩니다.
Config env 블록
인라인 환경 변수를 설정하는 두 가지 동등한 방법입니다(둘 다 덮어쓰지 않음).
셸 환경 가져오기
env.shellEnv는 로그인 셸을 실행하고 예상 키 중 누락된 키만 가져옵니다.
OPENCLAW_LOAD_SHELL_ENV=1OPENCLAW_SHELL_ENV_TIMEOUT_MS=15000
런타임 주입 환경 변수
OpenClaw은 생성된 자식 프로세스에 컨텍스트 마커도 주입합니다.OPENCLAW_SHELL=exec:exec도구를 통해 실행되는 명령에 설정됩니다.OPENCLAW_SHELL=acp: ACP 런타임 백엔드 프로세스 생성에 설정됩니다(예:acpx).OPENCLAW_SHELL=acp-client: ACP 브리지 프로세스를 생성할 때openclaw acp client에 설정됩니다.OPENCLAW_SHELL=tui-local: 로컬 TUI!셸 명령에 설정됩니다.
UI 환경 변수
OPENCLAW_THEME=light: 터미널 배경이 밝을 때 밝은 TUI 팔레트를 강제로 사용합니다.OPENCLAW_THEME=dark: 어두운 TUI 팔레트를 강제로 사용합니다.COLORFGBG: 터미널이 이를 내보내는 경우 OpenClaw은 배경색 힌트를 사용해 TUI 팔레트를 자동 선택합니다.
Config의 환경 변수 치환
${VAR_NAME} 구문을 사용해 Config 문자열 값에서 환경 변수를 직접 참조할 수 있습니다.
Secret refs와 ${ENV} 문자열
OpenClaw은 환경 변수 기반 패턴 두 가지를 지원합니다.
- Config 값의
${VAR}문자열 치환. - 비밀 참조를 지원하는 필드용 SecretRef 객체(
{ source: "env", provider: "default", id: "VAR" }).
경로 관련 환경 변수
| 변수 | 목적 |
|---|---|
OPENCLAW_HOME | 모든 내부 경로 해석에 사용하는 홈 디렉터리를 재정의합니다(~/.openclaw/, 에이전트 디렉터리, 세션, 자격 증명). 전용 서비스 사용자로 OpenClaw을 실행할 때 유용합니다. |
OPENCLAW_STATE_DIR | 상태 디렉터리를 재정의합니다(기본값 ~/.openclaw). |
OPENCLAW_CONFIG_PATH | Config 파일 경로를 재정의합니다(기본값 ~/.openclaw/openclaw.json). |
OPENCLAW_INCLUDE_ROOTS | $include 지시문이 Config 디렉터리 밖의 파일을 해석할 수 있는 디렉터리의 경로 목록입니다(기본값: 없음 — $include는 Config 디렉터리로 제한됨). 물결표가 확장됩니다. |
로깅
| 변수 | 목적 |
|---|---|
OPENCLAW_LOG_LEVEL | 파일과 콘솔 모두의 로그 수준을 재정의합니다(예: debug, trace). Config의 logging.level 및 logging.consoleLevel보다 우선합니다. 잘못된 값은 경고와 함께 무시됩니다. |
OPENCLAW_DEBUG_MODEL_TRANSPORT | 전역 디버그 로그를 활성화하지 않고 info 수준에서 대상 모델 요청/응답 타이밍 진단을 내보냅니다. |
OPENCLAW_DEBUG_MODEL_PAYLOAD | 모델 페이로드 진단: summary, tools 또는 full-redacted. full-redacted는 제한되고 수정되지만 프롬프트/메시지 텍스트를 포함할 수 있습니다. |
OPENCLAW_DEBUG_SSE | 스트리밍 진단: 첫/완료 타이밍은 events, 수정된 처음 5개의 SSE 이벤트를 포함하려면 peek. |
OPENCLAW_DEBUG_CODE_MODE | 제공자 도구 숨김 및 exec/wait 전용 강제를 포함한 코드 모드 모델 표면 진단입니다. |
OPENCLAW_HOME
설정된 경우 OPENCLAW_HOME은 모든 내부 경로 해석에서 시스템 홈 디렉터리($HOME / os.homedir())를 대체합니다. 이를 통해 헤드리스 서비스 계정에 대해 전체 파일 시스템 격리를 사용할 수 있습니다.
우선순위: OPENCLAW_HOME > $HOME > USERPROFILE > os.homedir()
예시(macOS LaunchDaemon):
OPENCLAW_HOME은 물결표 경로(예: ~/svc)로도 설정할 수 있으며, 사용 전에 $HOME을 사용해 확장됩니다.
nvm 사용자: web_fetch TLS 실패
Node.js가 시스템 패키지 관리자가 아니라 nvm을 통해 설치된 경우, 내장fetch()는
nvm에 번들된 CA 저장소를 사용하며, 최신 루트 CA(ISRG Root X1/X2 for Let’s Encrypt,
DigiCert Global Root G2 등)가 누락되어 있을 수 있습니다. 이로 인해 대부분의 HTTPS 사이트에서 web_fetch가 "fetch failed"로 실패합니다.
Linux에서 OpenClaw은 nvm을 자동으로 감지하고 실제 시작 환경에 수정 사항을 적용합니다.
openclaw gateway install은 systemd 서비스 환경에NODE_EXTRA_CA_CERTS를 씁니다.openclawCLI 진입점은 Node 시작 전에NODE_EXTRA_CA_CERTS가 설정된 상태로 자신을 다시 실행합니다.
node ... 실행용):
OpenClaw을 시작하기 전에 변수를 내보내세요.
~/.openclaw/.env에만 쓰는 방식에 의존하지 마세요. Node는 프로세스 시작 시
NODE_EXTRA_CA_CERTS를 읽습니다.
레거시 환경 변수
OpenClaw은OPENCLAW_* 환경 변수만 읽습니다. 이전 릴리스의 레거시
CLAWDBOT_* 및 MOLTBOT_* 접두사는 조용히
무시됩니다.
시작 시 Gateway 프로세스에 해당 변수가 설정되어 있으면 OpenClaw은
감지된 접두사와 총 개수를 나열하는 단일 Node 지원 중단 경고(OPENCLAW_LEGACY_ENV_VARS)를 내보냅니다. 각 값은
레거시 접두사를 OPENCLAW_로 바꿔 이름을 변경하세요(예: CLAWDBOT_GATEWAY_TOKEN →
OPENCLAW_GATEWAY_TOKEN). 이전 이름은 아무 효과가 없습니다.