安装方式
Nix
声明式安装 OpenClaw:使用 nix-openclaw,这是第一方、功能齐备的 Home Manager 模块。
你将获得什么
- Gateway 网关 + macOS 应用 + 工具(whisper、spotify、cameras)-- 全部固定版本
- 重启后仍会保留的 launchd 服务
- 带声明式配置的插件系统
- 即时回滚:
home-manager switch --rollback
快速开始
安装 Determinate Nix
如果尚未安装 Nix,请按照 Determinate Nix 安装器说明操作。
创建本地 flake
使用 nix-openclaw 仓库中的 agent 优先模板:
mkdir -p ~/code/openclaw-local
# Copy templates/agent-first/flake.nix from the nix-openclaw repo
配置密钥
设置你的消息传递 bot 令牌和模型提供商 API key。放在 ~/.secrets/ 下的纯文件即可。
填写模板占位符并切换
home-manager switch
验证
确认 launchd 服务正在运行,并且你的 bot 会响应消息。
请参阅 nix-openclaw README,了解完整的模块选项和示例。
Nix 模式运行时行为
设置 OPENCLAW_NIX_MODE=1 时(使用 nix-openclaw 会自动设置),OpenClaw 会进入用于 Nix 托管安装的确定性模式。其他 Nix 包也可以设置同一模式;nix-openclaw 是第一方参考实现。
你也可以手动设置:
export OPENCLAW_NIX_MODE=1
在 macOS 上,GUI 应用不会自动继承 shell 环境变量。请改用 defaults 启用 Nix 模式:
defaults write ai.openclaw.mac openclaw.nixMode -bool true
Nix 模式会改变什么
- 自动安装和自我变更流程会被禁用
openclaw.json会被视为不可变。启动时派生的默认值只保留在运行时,并且设置、新手引导、会修改配置的openclaw update、插件安装/更新/卸载/启用、doctor --fix、doctor --generate-gateway-token和openclaw config set等配置写入器都会拒绝编辑该文件。- Agent 应改为编辑 Nix 源。对于 nix-openclaw,请使用 agent 优先的快速开始,并在
programs.openclaw.config或instances.<name>.config下设置配置。 - 缺失依赖会显示 Nix 专用的修复消息
- UI 会显示只读 Nix 模式横幅
配置和状态路径
OpenClaw 从 OPENCLAW_CONFIG_PATH 读取 JSON5 配置,并将可变数据存储在 OPENCLAW_STATE_DIR 中。在 Nix 下运行时,请将这些路径显式设置为 Nix 托管位置,确保运行时状态和配置不会进入不可变 store。
| 变量 | 默认值 |
|---|---|
OPENCLAW_HOME |
HOME / USERPROFILE / os.homedir() |
OPENCLAW_STATE_DIR |
~/.openclaw |
OPENCLAW_CONFIG_PATH |
$OPENCLAW_STATE_DIR/openclaw.json |
服务 PATH 发现
launchd/systemd Gateway 网关服务会自动发现 Nix profile 二进制文件,因此
通过 shell 调用 nix 安装可执行文件的插件和工具无需
手动设置 PATH 即可工作:
- 设置
NIX_PROFILES时,每个条目都会按 从右到左的优先级加入服务 PATH(与 Nix shell 优先级一致 -- 最右侧获胜)。 - 未设置
NIX_PROFILES时,会将~/.nix-profile/bin作为回退加入。
这同时适用于 macOS launchd 和 Linux systemd 服务环境。