其他

关注公众号 jb51net

关闭
AI > 其他 >

Hermes Agent迁移到外部硬盘的详细教程

Learning_By Doing

背景

Hermes Agent 默认将所有数据存储在 ~/.hermes/,包括程序本体(venv、node_modules)和用户数据(sessions、memories、skills 等)。随着使用,这个目录会持续增长。本教程记录如何将其迁移到外部硬盘以节省内置 SSD 空间。

前提条件

迁移步骤

Step 1: 停止 Hermes

# 检查 Hermes 是否在运行
ps aux | grep -i hermes | grep -v grep
# 如果在运行,停止它
hermes stop
# 或者强制终止
pkill -f hermes

重要:必须在 Hermes 完全停止后再操作,否则可能导致数据损坏。

Step 2: 确认外部硬盘状态

# 查看已挂载的外部卷
ls /Volumes/

# 确认文件系统类型(必须是 APFS 或 HFS+)
diskutil info /Volumes/你的硬盘名 | grep "File System"

# 确认可用空间
df -h /Volumes/你的硬盘名

Step 3: 移动数据到外部硬盘

# 将 ~/.hermes 整体移动到外部硬盘(目录名可自定义)
mv ~/.hermes /Volumes/你的硬盘名/.hermes

为什么用 mv 而不是 cp
mv 在同一文件系统上是瞬间完成的(只改指针)。跨文件系统时等同于 cp + rm,但更简洁。

Step 4: 创建符号链接

# 在原位置创建指向外部硬盘的符号链接
ln -s /Volumes/你的硬盘名/.hermes ~/.hermes

为什么用符号链接而不是 HERMES_HOME 环境变量?

Hermes 的 Python 虚拟环境(venv)中所有脚本的 shebang 都硬编码了
#!/Users/你的用户名/.hermes/hermes-agent/venv/bin/python3 这样的路径。
如果用 HERMES_HOME 指向新位置,venv 内部的路径全部断裂,导致 hermes 命令无法运行。

符号链接让系统"以为"数据还在 ~/.hermes/,所有硬编码路径都能正常解析。

Step 5: 验证

# 确认符号链接正确
ls -la ~/.hermes
# 应输出: ~/.hermes -> /Volumes/你的硬盘名/.hermes

# 确认 hermes 命令可用
hermes --version

# 确认配置文件可访问
cat ~/.hermes/config.yaml

推出外部硬盘前的操作

必须先停止 Hermes 再推出硬盘! 否则会导致:

安全推出流程

# 1. 停止 Hermes
hermes stop 2>/dev/null
pkill -f hermes 2>/dev/null

# 2. 确认没有进程在访问外部硬盘
lsof +D /Volumes/你的硬盘名/.hermes 2>/dev/null

# 如果有输出,说明还有进程在使用,需要逐一关闭或 kill
# 例如:kill <PID>

# 3. 安全推出
diskutil eject /Volumes/你的硬盘名
# 或者在 Finder 中点击推出按钮

重新插入硬盘后

插入硬盘后 Hermes 会自动恢复可用(因为符号链接会重新生效),直接运行 hermes 即可。

回滚(迁移回内置硬盘)

如果需要将数据迁回内置硬盘:

# 1. 停止 Hermes
hermes stop 2>/dev/null && pkill -f hermes 2>/dev/null

# 2. 删除符号链接
rm ~/.hermes

# 3. 移回数据
mv /Volumes/你的硬盘名/.hermes ~/.hermes

# 4. 验证
hermes --version

目录结构参考

~/.hermes/                          → 符号链接到外部硬盘
├── hermes-agent/                   (程序本体 ~1 GB)
│   ├── venv/                       (Python 虚拟环境, ~538 MB)
│   ├── ui-tui/                     (TUI 界面, ~191 MB)
│   ├── node_modules/               (Node.js 依赖, ~146 MB)
│   ├── skills/                     (内置技能)
│   └── agent/                      (核心代理逻辑)
├── skills/                         (自定义/学习到的技能, 会增长)
├── sessions/                       (会话历史, 会增长)
├── memories/                       (跨会话记忆, 会增长)
├── audio_cache/                    (语音缓存, 会增长)
├── image_cache/                    (图片缓存, 会增长)
├── config.yaml                     (配置文件)
├── SOUL.md                         (Agent 人格定义)
├── auth.json                       (API 密钥)
└── state.db                        (状态数据库)

重命名外部硬盘上的目录

如果你对外部硬盘上的目录名不满意(比如想从 hermes-data 改为 .hermes),可以随时重命名:

# 1. 停止 Hermes
hermes stop 2>/dev/null && pkill -f hermes 2>/dev/null

# 2. 删除旧的符号链接
rm ~/.hermes

# 3. 重命名外部硬盘上的目录
mv /Volumes/你的硬盘名/旧目录名 /Volumes/你的硬盘名/新目录名

# 4. 重新创建符号链接指向新名称
ln -s /Volumes/你的硬盘名/新目录名 ~/.hermes

# 5. 验证
ls -la ~/.hermes
hermes --version

注意. 开头的目录在 Finder 中默认隐藏。按 Cmd + Shift + . 可以切换显示隐藏文件。

操作记录

初次迁移 (2026-04-22)

目录重命名 (2026-04-22)

踩坑记录:为什么不能用 HERMES_HOME 环境变量

以上就是Hermes Agent迁移到外部硬盘的详细教程的详细内容,更多关于Hermes Agent迁移到外部硬盘的资料请关注脚本之家其它相关文章!