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

  发布时间:2026-04-23 14:39:29   作者:Learning_By Doing   我要评论
本文详细介绍了将OS系统HermesAgent将数据迁移到外部硬盘以节省内置SSD空间的过程,步骤包括停止HermesAgent、确认外部硬盘状态、移动数据、创建建建符号链接等确保迁移后的正常运行,需要的朋友可以参考下

背景

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

前提条件

  • 外部硬盘格式为 APFSMac OS Extended (HFS+)(不支持 NTFS/exFAT,因为需要符号链接和 Unix 权限)
  • 外部硬盘有足够可用空间(当前 Hermes 占 ~1 GB,随使用会增长)

迁移步骤

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 再推出硬盘! 否则会导致:

  • 进程崩溃或挂起(无法读写数据文件)
  • macOS 可能拒绝推出硬盘(提示"磁盘正在使用中")
  • 最坏情况:数据库文件(state.db)损坏

安全推出流程

# 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)

  • 源路径: ~/.hermes/ (1.0 GB, 71213 个文件)
  • 目标路径: /Volumes/WDBlueSN5000/hermes-data/
  • 外部硬盘: WD Blue SN5000 (931 GB APFS)
  • 方案: 符号链接(~/.hermes → 外部硬盘)
  • 验证: rsync 复制后对比文件数量一致,hermes v0.10.0 正常运行

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

  • 操作: 将外部硬盘上的 hermes-data 重命名为 .hermes
  • 步骤: 删除符号链接 → mv 重命名 → 重建符号链接
  • 最终路径: ~/.hermes/Volumes/WDBlueSN5000/.hermes
  • 验证: hermes v0.10.0 正常运行

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

  • 最初尝试设置 export HERMES_HOME="/Volumes/WDBlueSN5000/hermes-data" 并直接 mv 整个目录
  • 结果: hermes 命令无法运行,因为 venv 内脚本的 shebang 硬编码了 #!/Users/cc/.hermes/hermes-agent/venv/bin/python3
  • 解决: 改用符号链接方案,让所有硬编码路径透明解析到外部硬盘

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

相关文章

最新评论