WSL2 安装 OpenClaw(Windows)

OpenClaw 官方文档 建议通过WSL2(推荐Ubuntu)在Windows上使用。CLI + Gateway在Linux内运行,这样可以保持了运行时的一致性,并使工具能够兼容(Node/Bun/pnpm,Linux二进制文件,技能)。原生Windows可能遇到一些棘手的情况。WSL2为您提供完整的Linux体验------一个安装命令:wsl --install

截止发文日,原生Windows配套应用程序还在计划中。

当让,你最好对计算机,特别是 Ubuntu 有一定了解再尝试通过wsl安装。

这在调用本机浏览器时也比较麻烦。

1. Install (WSL2)

1.1安装发行版

如果你已经安装,可以忽略这一步

ps 复制代码
wsl --install

此命令将启用运行WSL和安装Linux的Ubuntu发行版所需的功能。

参考文档 Install WSL| Microsoft Learn.

安装完毕之后,打开 ubuntu,你需要为新的发行版设定用户名和密码。

如果太久不用,密码忘记了

通过下面命令, 换成你要重置密码的发行版名称。

sh 复制代码
wsl -d <DistroName> -u root

登陆之后,重置 的密码。

sh 复制代码
passwd <username> 

1.2启动 systemd

sh 复制代码
sudo tee /etc/wsl.conf >/dev/null <<'EOF'
[boot]
systemd=true
EOF

1.3 重启 wsl

在 Powershell中

sh 复制代码
wsl --shutdown

重新进入wsl

sh 复制代码
systemctl --user status

2. 安装 OpenClaw

sh 复制代码
curl -fsSL https://openclaw.ai/install.sh | bash

3. 安装为服务

sh 复制代码
openclaw onboard --install-daemon

检查服务状态

sh 复制代码
openclaw gateway status

4. 配置在 Windows 登录前自动启动

可选,如果你想让这个服务在登录电脑之前就能用,服务器比较需要这个功能。

在 wsl 中运行

sh 复制代码
sudo loginctl enable-linger "$(whoami)"
openclaw gateway install

在 Windows Powershell中执行

将下面命令中的换成你的发行版。

sh 复制代码
schtasks /create /tn "WSL Boot" /tr "wsl.exe -d <DistroName> --exec /bin/true" /sc onstart /ru SYSTEM

检查登录前启动是否配置成功

在wsl中运行

sh 复制代码
systemctl --user is-enabled openclaw-gateway
systemctl --user status openclaw-gateway --no-pager

5. 将wsl中的服务暴露给外部网络

还是服务器需要的功能。

WSL有自己的虚拟网络。如果另一台机器需要访问在WSL内运行的服务(SSH、本地TTS服务器或网关),您必须将Windows端口转发到当前的WSL IP。WSL IP在重新启动后会发生变化,因此您可能需要刷新转发规则。

添加映射

用管理员模式启动 Powershell:

sh 复制代码
$Distro = "Ubuntu-24.04"
$ListenPort = 18000
$TargetPort = 18789

$WslIp = (wsl -d $Distro -- hostname -I).Trim().Split(" ")[0]
if (-not $WslIp) { throw "WSL IP not found." }

netsh interface portproxy add v4tov4 listenaddress=0.0.0.0 listenport=$ListenPort `
  connectaddress=$WslIp connectport=$TargetPort

添加防火墙允许规则

只需要开一次

sh 复制代码
New-NetFirewallRule -DisplayName "WSL SSH $ListenPort" -Direction Inbound `
  -Protocol TCP -LocalPort $ListenPort -Action Allow

在WSL重启后,刷新端口代理

sh 复制代码
netsh interface portproxy delete v4tov4 listenport=$ListenPort listenaddress=0.0.0.0 | Out-Null
netsh interface portproxy add v4tov4 listenport=$ListenPort listenaddress=0.0.0.0 `
  connectaddress=$WslIp connectport=$TargetPort | Out-Null
相关推荐
qq_369224331 小时前
Windows系统缺失ddraw.dll文件?游戏闪退、图形报错原因详解及处理办法
windows·游戏·dll·dll修复·dll丢失·dll错误
林下溪畔2 小时前
部署claude code(Windows版)
windows
J&A~ing3 小时前
第一章 opencv 的 Windows源码在 Visual Studio 下的编译安装
人工智能·windows·opencv·计算机视觉·visual studio
2501_939998205 小时前
【2026.5.19 更新】 Win11 25H2 26200.8521 镜像下载
windows
ni_darling7 小时前
win11任务栏居左,win11右键菜单栏设置,win11改回win10设置项
windows
玖釉-7 小时前
旋转图像:从矩阵转置、镜像到坐标变换的系统理解
c++·windows·算法·图形渲染
家有两宝,感恩遇见7 小时前
windows安装claude code
windows
yaoxin5211238 小时前
414. Java 文件操作基础 - 批量压缩与索引:将154首十四行诗高效存储为带目录的二进制文件
java·windows·python
早睡身体真不戳8 小时前
Cacheable List 接口二次读取报错
windows
shandianchengzi8 小时前
【记录】联想|Thinkpad雷电接口连接带鱼屏显示器,画面被异常拉伸怎么解决?
windows·计算机外设·显示器·联想·thinkpad