Ubuntu 远程访问 Win11 WSL2 并固定访问教程

本文介绍如何在局域网内从另一台 Ubuntu 远程访问 Windows 11 的 WSL2,并解决 WSL2 IP 动态变化导致的端口转发失效问题。


1. 确认 WSL2 的 SSH 服务

在 Win11 中打开 WSL2(Ubuntu),执行:

bash 复制代码
sudo service ssh status

如果显示:

复制代码
* sshd is running

说明 SSH 服务已启动。

如果未启动,请执行:

bash 复制代码
sudo service ssh start

然后检查端口是否监听:

bash 复制代码
sudo netstat -tlnp | grep ssh

输出示例:

复制代码
tcp   0   0 0.0.0.0:22    0.0.0.0:*   LISTEN   6792/sshd
tcp6  0   0 :::22         :::*        LISTEN   6792/sshd

表示 SSH 服务在 WSL2 正常运行。


2. 获取 WSL2 的 IP 地址

执行:

bash 复制代码
ip addr show eth0

输出示例:

复制代码
inet 172.28.145.147/20 brd 172.28.159.255 scope global eth0

这里 172.28.145.147 即为 WSL2 的当前 IP。

⚠️ 注意:WSL2 IP 每次重启可能变化,不能固定。


3. 测试从 Win11 本机 SSH 到 WSL2

在 Win11 CMD 中执行:

cmd 复制代码
ssh name@172.28.145.147

如果能登录,说明 WSL2 SSH 正常。


4. 配置 Win11 端口转发,供外部 Ubuntu 访问

由于 WSL2 位于 NAT 内部,外部 Ubuntu 需要访问 Win11 的 LAN IP 并通过端口转发访问 WSL2。

假设 Win11 局域网 IP 为 192.168.0.51,WSL2 IP 为 172.28.145.147

4.1 添加端口转发

管理员权限打开 PowerShell,执行:

powershell 复制代码
netsh interface portproxy add v4tov4 `
    listenport=2222 listenaddress=0.0.0.0 `
    connectport=22 connectaddress=172.28.145.147

4.2 开放防火墙端口

powershell 复制代码
New-NetFirewallRule -DisplayName "WSL2 SSH" -Direction Inbound -Protocol TCP -LocalPort 2222 -Action Allow

4.3 验证端口转发规则

powershell 复制代码
netsh interface portproxy show all

输出示例:

复制代码
Listen on ipv4:             Connect to ipv4:

Address         Port        Address             Port
--------------- ----------  ------------------  ----------
0.0.0.0         2222        172.28.145.147      22

5. 从 Ubuntu 外部 SSH 访问 WSL2

在 Ubuntu 上执行:

bash 复制代码
ssh name@192.168.x.xxx -p 2222

成功登录即表示远程访问配置完成。


6. 解决 WSL2 IP 动态变化问题(自动更新端口转发)

6.1 创建自动更新脚本

在 Win11 中创建文件 C:\wsl_portproxy.ps1,内容如下:

powershell 复制代码
# 获取 WSL2 当前 IP
$wsl_ip = wsl.exe hostname -I
$wsl_ip = $wsl_ip.Trim()

# 删除旧规则
netsh interface portproxy delete v4tov4 listenport=2222 listenaddress=0.0.0.0

# 添加新规则
netsh interface portproxy add v4tov4 listenport=2222 listenaddress=0.0.0.0 connectport=22 connectaddress=$wsl_ip

Write-Host "WSL2 SSH portproxy updated to $wsl_ip"

6.2 允许 PowerShell 脚本执行

以管理员 PowerShell 执行:

powershell 复制代码
Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy RemoteSigned

6.3 创建开机自动任务

在管理员 PowerShell 中执行:

powershell 复制代码
schtasks /create /sc onlogon /tn "UpdateWSL2Proxy" /tr "powershell.exe -NoProfile -ExecutionPolicy Bypass -File C:\wsl_portproxy.ps1" /RL HIGHEST /F

6.4 验证任务创建成功

powershell 复制代码
schtasks /query | findstr UpdateWSL2Proxy

7. 最终效果

  1. 每次 Win11 登录时,自动更新 WSL2 的端口转发。
  2. 外部 Ubuntu 永远可通过:
bash 复制代码
ssh name@192.168.x.xxx -p 2222
  1. 无需手动修改 WSL2 IP 或 portproxy。

8. 拓展(可选)

如果 WSL2 中有其他服务(Flask、TensorBoard、ROS 等),可在 C:\wsl_portproxy.ps1 中添加更多端口转发,例如:

powershell 复制代码
# Flask 默认 5000
netsh interface portproxy add v4tov4 listenport=5000 listenaddress=0.0.0.0 connectport=5000 connectaddress=$wsl_ip

# TensorBoard 默认 6006
netsh interface portproxy add v4tov4 listenport=6006 listenaddress=0.0.0.0 connectport=6006 connectaddress=$wsl_ip

这样就可以一键访问所有常用服务。


参考

相关推荐
chlk1231 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑1 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件2 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
碳基沙盒2 天前
OpenClaw 多 Agent 配置实战指南
运维
深紫色的三北六号2 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash2 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux
蝎子莱莱爱打怪4 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes