分类
wsl

WSL2 使用 ssh-server 笔记

升级到 WSL2 之后,我面临几个问题:

  • webpack-dev-server 无法监控 /mnt/c/xxxx 这样的路径下的文件变化,使得 HMR 失效。只能借由 ~/path/to/project/ 启动开发环境。
  • 启动服务后,无法通过 127.0.0.1:port/ 访问,只能通过 localhost:port 访问。

今天想使用 ssh-server 连上去,结果失败,经查,原来 WSL2 的底层逻辑变了:

If this is WSL2 (which it appears to be) this is for all intents by-design. WSL2 has its own Real Linux™ network stack inside a VM, and a virtual Ethernet device. Contrast WSL1 which took the approach of attempting to present the Windows network stack inside Linux.

WSL2 就是这么设计的。它在虚拟机里有自己真实的 Linux 网络栈,以及虚拟的以太网设备。

WSL2: ifconfig not showing all network connections · Issue #4915 · microsoft/WSL (github.com)

所以要用不同的方式来做,记录在这篇笔记里。

方案一:使用 ssh-server

1. 在 Windows 里安装 ssh-server

  1. 设置 > 应用 > 应用和功能 > 可选功能 > 添加功能
  2. 搜索并安装 ssh-sever
  3. 启动 ssh-server,需使用管理员身份启动 powershell
# 启动 ssh 服务
Start-Service sshd

# 可选,设置 sshd 为开机自动启动
Set-Service -Name sshd -StartupType 'Automatic'

# 往防火墙里添加规则
if (!(Get-NetFirewallRule -Name "OpenSSH-Server-In-TCP" -ErrorAction SilentlyContinue | Select-Object Name, Enabled)) {
    Write-Output "Firewall Rule 'OpenSSH-Server-In-TCP' does not exist, creating it..."
    New-NetFirewallRule -Name 'OpenSSH-Server-In-TCP' -DisplayName 'OpenSSH Server (sshd)' -Enabled True -Direction Inbound -Protocol TCP -Action Allow -LocalPort 22
} else {
    Write-Output "Firewall rule 'OpenSSH-Server-In-TCP' has been created and exists."
}

2. ssh 连接

在另外一台机器上输入 ssh username@ip-or-host 即可完成连接。

不过需要注意的是,比如我的账户名为 Meathill Zhai,这个名称不能直接使用。我的邮箱是 realmeathill[at]hotmail.com,系统会自动截取一段,我在命令行里的初始位置是:C:\Users\realm,于是登录的时候只能用 ssh realm@ip,然后输入 realmeathill[at]hotmail.com 的密码,方能完成登录。

3. 改为连接 WSL2

默认情况下,使用 ssh 连入的命令行是 cmd.exe,可以通过以下命令修改为 Powershell:

New-ItemProperty -Path "HKLM:\SOFTWARE\OpenSSH" -Name DefaultShell -Value "C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe" -PropertyType String -Force

如果把里面的 WindowsPowerShell\v1.0\powershell.exe 修改为 bash.exe,那么就会连入 WSL2 了。

4. 改回 powershell

直接连入WSL2 也不是不行,不过这样的话,一些涉及 Windows 系统的操作无法进行,exit 也是直接退出 ssh 连接。于是我觉得默认连入 powershell 比较好,想用 WSL 就手动 bash 进入 WSL 即可。

待解决问题

  • powershell ssh-server 不支持 authorized_keys 登录

参考文章

meathill

爱编程,爱旅游,爱吐槽。
今年的目标是完成并运营至少一个 Side Project。
《Electron + Vue 实战开发》龟速创作中……

欢迎吐槽,共同进步

此站点使用Akismet来减少垃圾评论。了解我们如何处理您的评论数据