最近在自己的电脑上使用 WSL 技术来搭建部分开发环境,一个是习惯了 Linux 的操作,另一个是不用时方便卸载清理。
我在子系统中,安装了一个 MySQL,然后试图通过局域网内的另一台电脑使用 Navicat 连接 MySQL,结果出现了下面的错误:
2002 - Can't connect to server on 'MySQL所在电脑的IP'
开始以为没给 root 账号开放远程访问,进入 CLI 查看,发现已经支持远程访问(%
):
MariaDB [mysql]> select host,user from user;
+-----------+------+
| host | user |
+-----------+------+
| % | root |
| localhost | root |
+-----------+------+
2 rows in set (0.00 sec)
后来翻阅 WSL 文档 找到了线索:
当使用 WSL 1 分发版时,如果计算机设置为可供 LAN 访问,那么在 WSL 中运行的应用程序也可供在 LAN 中访问。
这不是 WSL 2 中的默认情况。 WSL 2 有一个带有其自己独一无二的 IP 地址的虚拟化以太网适配器。 目前,若要启用此工作流,你需要执行与常规虚拟机相同的步骤。 (我们正在寻找改善此体验的方法。)
大致意思就是 WSL 2 有自己的IP地址,只能在主机上访问 WSL,官方给出方案,使用 netsh interface portproxy
在主机上监听端口并转发到 WSL 中,下面就来操刀!
步骤1 - 获取子系统 IP
在 WSL 子系统 中执行命令,我安装的是 Ubuntu:
$ ip addr show eth0
得到 IP 地址,我的是:172.21.19.66
步骤2 - 端口转发
命令格式:
netsh interface portproxy add v4tov4 listenaddress=0.0.0.0 listenport=[主机监听的端口] connectport=[转发到 WSL 的端口] connectaddress=[WSL IP 地址]
在 Windows 中执行的命令:
netsh interface portproxy add v4tov4 listenaddress=0.0.0.0 listenport=3306 connectport=3306 connectaddress=172.21.19.66
再次尝试连接 MySQL(192.168.31.175 是我电脑的内网IP):
其他 - 删除转发
命令格式:
netsh interface portproxy delete v4tov4 listenaddress=0.0.0.0 listenport=[主机监听的端口]
在 Windows 中执行的命令:
netsh interface portproxy delete v4tov4 listenaddress=0.0.0.0 listenport=3306
参考
- 使用 WSL 访问网络应用程序 - https://learn.microsoft.com/zh-cn/windows/wsl/networking
Windows WSL2 内网之间无法访问