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

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


参考

相关推荐
Rabbit_QL15 小时前
【ln -s】Linux 软链接在大模型部署中的应用
linux·运维·服务器
LT101579744415 小时前
2026年超自动化平台选型指南:全流程智能协同适配
运维·人工智能·自动化
坤昱16 小时前
cfs调度类深入解刨——核心结构细节分析
linux·cfs调度·eevdf调度·linux调度·linux技术
枳实-叶16 小时前
【Linux驱动开发】第12天:Linux设备树核心:树形结构+节点+属性 完整全解
linux·运维·驱动开发
Yeats_Liao16 小时前
物联网接入层技术剖析(三):epoll在JVM中的映射
java·linux·jvm·人工智能·物联网
悠悠1213816 小时前
Jenkins + Ansible 集成实战:把配置管理焊进流水线里
运维·ansible·jenkins
日取其半万世不竭16 小时前
用 n8n 搭建自己的自动化工作流平台
运维·自动化
小贾要学习16 小时前
【Linux】基于自定义TCP协议的日期计算器
linux·网络·c++·网络协议·tcp/ip
IT界的老黄牛16 小时前
从 MQ 积压追到事件总线:诊断 4K 线程吃光 7G 内存的实战
java·运维·rocketmq
2501_9200470317 小时前
iptables防火墙
linux·运维·网络安全