Containers
Nix
OpenClaw를 선언적으로 설치하려면 **nix-openclaw**를 사용하세요. 이는 필요한 기능이 모두 포함된 공식 Home Manager 모듈입니다.
제공되는 것
- Gateway + macOS 앱 + 도구(whisper, spotify, cameras) -- 모두 고정됨
- 재부팅 후에도 유지되는 launchd 서비스
- 선언적 설정을 지원하는 Plugin 시스템
- 즉시 롤백:
home-manager switch --rollback
빠른 시작
Determinate Nix 설치
Nix가 아직 설치되어 있지 않다면 Determinate Nix installer 지침을 따르세요.
로컬 flake 만들기
nix-openclaw 저장소의 agent-first 템플릿을 사용하세요.
mkdir -p ~/code/openclaw-local
# Copy templates/agent-first/flake.nix from the nix-openclaw repo
시크릿 설정
메시징 봇 토큰과 모델 제공자 API 키를 설정하세요. ~/.secrets/의 일반 파일로도 충분합니다.
템플릿 플레이스홀더를 채우고 전환
home-manager switch
확인
launchd 서비스가 실행 중이고 봇이 메시지에 응답하는지 확인하세요.
전체 모듈 옵션과 예시는 nix-openclaw README를 참조하세요.
Nix 모드 런타임 동작
OPENCLAW_NIX_MODE=1이 설정되면(nix-openclaw에서는 자동), OpenClaw는 Nix로 관리되는 설치를 위한 결정적 모드로 들어갑니다. 다른 Nix 패키지도 같은 모드를 설정할 수 있으며, nix-openclaw가 공식 참조 구현입니다.
수동으로 설정할 수도 있습니다.
export OPENCLAW_NIX_MODE=1
macOS에서는 GUI 앱이 셸 환경 변수를 자동으로 상속하지 않습니다. 대신 defaults를 통해 Nix 모드를 활성화하세요.
defaults write ai.openclaw.mac openclaw.nixMode -bool true
Nix 모드에서 변경되는 사항
- 자동 설치 및 자체 변경 흐름이 비활성화됩니다.
openclaw.json은 변경 불가능한 것으로 취급됩니다. 시작 시 파생되는 기본값은 런타임에만 유지되며, setup, onboarding, 변경을 수행하는openclaw update, Plugin install/update/uninstall/enable,doctor --fix,doctor --generate-gateway-token,openclaw config set같은 설정 작성기는 파일 편집을 거부합니다.- 대신 에이전트는 Nix 소스를 편집해야 합니다. nix-openclaw의 경우 agent-first 빠른 시작을 사용하고
programs.openclaw.config또는instances.<name>.config아래에 설정을 지정하세요. - 누락된 의존성은 Nix 전용 해결 메시지로 표시됩니다.
- UI는 읽기 전용 Nix 모드 배너를 표시합니다.
설정 및 상태 경로
OpenClaw는 OPENCLAW_CONFIG_PATH에서 JSON5 설정을 읽고 OPENCLAW_STATE_DIR에 변경 가능한 데이터를 저장합니다. Nix에서 실행할 때는 런타임 상태와 설정이 변경 불가능한 저장소 밖에 있도록 이를 Nix가 관리하는 위치로 명시적으로 설정하세요.
| 변수 | 기본값 |
|---|---|
OPENCLAW_HOME |
HOME / USERPROFILE / os.homedir() |
OPENCLAW_STATE_DIR |
~/.openclaw |
OPENCLAW_CONFIG_PATH |
$OPENCLAW_STATE_DIR/openclaw.json |
서비스 PATH 검색
launchd/systemd Gateway 서비스는 Nix 프로필 바이너리를 자동으로 검색하므로
shell로 nix로 설치된 실행 파일을 호출하는 Plugin과 도구가
수동 PATH 설정 없이 작동합니다.
NIX_PROFILES가 설정된 경우, 모든 항목이 오른쪽에서 왼쪽으로 우선순위를 적용하여 서비스 PATH에 추가됩니다 (Nix 셸 우선순위와 일치 - 가장 오른쪽이 우선).NIX_PROFILES가 설정되지 않은 경우,~/.nix-profile/bin이 대체 경로로 추가됩니다.
이는 macOS launchd와 Linux systemd 서비스 환경 모두에 적용됩니다.