一、问题背景
在使用 WSL 2 开发和运行 Python 项目时,很多开发者都会遇到以下问题:
关闭 PowerShell 或 Windows Terminal 后,WSL 自动退出,正在运行的 Hermes Agent也随之停止。
这是 WSL 2 的默认行为:当虚拟机内没有活跃 Linux 进程时,WSL 会自动关闭以节省资源。
本文将详细介绍如何让 WSL 保持后台运行,并让你的 Hermes Agent 作为系统服务稳定持久运行。
二、WSL 2 终止机制原理解析
WSL 2 是一个轻量级 Hyper-V 虚拟机。当满足以下任意条件时,它会自动终止:
- 没有正在运行的 Linux 进程
- 没有活跃的终端会话
- 超过空闲超时
使用 sleep infinity 等粗暴方式虽然可行,但资源占用较高。最佳实践是启动一个轻量级守护进程(如 D-Bus)来保活。
三、最佳保活方案:使用 dbus-launch
核心启动命令:
cmd
@start /b wsl --exec dbus-launch true
原理说明:
start /b:后台静默运行,不弹出窗口--exec:直接执行命令,不启动交互式 Shelldbus-launch true:启动 D-Bus Session Bus 守护进程(true命令立即退出),让 WSL 认为有进程在运行,从而保持虚拟机活跃
该方案资源占用极低,是目前最优雅的 WSL 后台保活方式。
四、完整实施步骤
1. 创建开机自启动文件
按 Win + R,输入以下路径打开启动文件夹:
css
%APPDATA%\Microsoft\Windows\Start Menu\Programs\Startup
新建文件 wslstart.cmd,内容如下:
bash
@echo off
:: 保持 WSL 后台运行,供 Hermes Agent 使用
start /b wsl -d Ubuntu --exec dbus-launch true
(将 Ubuntu 替换为你实际的发行版名称)
重启电脑后,WSL 将自动在后台运行。
五、如何连接到后台运行的 WSL 实例
bash
wsl # 最简单方式
wsl -d Ubuntu # 指定发行版
wsl -d Ubuntu -u wanjing # 指定用户名
推荐使用 Windows Terminal 作为日常终端。
六、使用 systemd 管理服务, 让 Hermes Agent 自动启动并持久运行
Hermes Agent 推荐使用 systemd 管理服务(WSL2 已原生支持)。
步骤如下:
- 启用 systemd
bash
sudo vim /etc/wsl.conf
添加以下内容:
ini
[boot]
systemd=true
- 创建 systemd 服务文件
安装 Hermes Agent后, 使用下面命令会自动创建 systemd服务
css
sudo hermes gateway install --system
- 查看服务
bash
# 查看服务状态
sudo systemctl status hermes-gateway.service
七、常用管理命令
perl
wsl -l -v # 查看 WSL 状态
wsl --shutdown # 完全关闭 WSL(释放资源)
wsl -d Ubuntu # 连接到后台实例
八、总结
通过以下组合方案,我们完美解决了 WSL 退出问题:
wslstart.cmd+dbus-launch→ 保持 WSL 后台常驻systemd服务 → 让 Hermes Agent 自动、重启、持久运行
现在即使你关闭所有终端窗口,甚至注销 Windows,Hermes Agent 依然能在后台稳定运行。