windows10 2004 版使用 WSL2 并自动转发 WSL2 中端口
一. 安装 windows10 2004 版
建议全新安装 windows10 2004,升级到 2004 版时开机启动项在没有登录系统时不能运行开机启动项里的程序。
二. 安装 WSL2
以管理员身份打开 PowerShell 并运行以下命令
- 启用 “适用于 Linux 的 Windows 子系统” 可选功能
dism.exe /online /enable-feature /featurename:Microsoft-Windows-Subsystem-Linux /all /norestart
- 安装 WSL 2 之前,必须启用 “虚拟机平台” 可选功能,
dism.exe /online /enable-feature /featurename:VirtualMachinePlatform /all /norestart
-
重新启动计算机
-
WSL 2 需要更新其内核组件
下载地址: https://wslstorestorage.blob.core.windows.net/wslblob/wsl_update_x64.msi -
将 WSL 2 设置为默认版本
wsl --set-default-version 2
- 使用 Store 安装 Linux 分发版
三. 安装 docker
- 安装依赖
sudo apt update
sudo apt install apt-transport-https ca-certificates curl gnupg2 software-properties-common
- 信任 Docker 的 GPG 公钥
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
- 添加软件仓库
sudo add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
- 安装 docker
sudo apt update
sudo apt install docker-ce
- 将当前用户添加到 docker 用户组
sudo adduser $USER docker
- 运行 docker
sudo service docker start
四. Windows10 开机自动启动 WSL2 并转发服务
- 安装 ssh,nginx 等服务
#wsl2中安装好的openssh-server有问题需卸载后重新安装
sudo apt remove openssh-server
sudo apt install openssh-server nginx -y
- WSL2 中增加配置,开机启动服务
sudo cat > /etc/init.wsl << EOF
#!/bin/sh
/etc/init.d/ssh start
/etc/init.d/nginx start
EOF
sudo chmod +x /etc/init.wsl
- golang 程序,运行方法:startwsl.exe -run=Ubuntu-18.04,此程序自动获取 WSL2 中服务端口并做转发,使 WSL2 中的服务能对局域网提供服务
package main
import (
"flag"
"fmt"
"os/exec"
"regexp"
"strings"
"time"
)
func main() {
wslName := flag.String("run", "", "wsl2 name")
flag.Parse()
if *wslName != "" {
if err := exec.Command("wsl", "-d", *wslName, "-u", "root", "/etc/init.wsl").Run(); err != nil {
panic(err)
}
}
time.Sleep(5 * time.Second)
// 获取WSL2 IP地址
result, err := exec.Command("wsl", "ifconfig", "eth0").Output()
if err != nil {
panic(err)
}
var valid = regexp.MustCompile("((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})(\\.((2(5[0-5]|[0-4]\\d))|[0-1]?\\d{1,2})){3}")
wslIP := valid.FindAllString(string(result), -1)[0]
res, err := exec.Command("wsl", "netstat", "-lntp").Output()
if err != nil {
panic(err)
}
var reg = regexp.MustCompile(":(\\d{1,5})")
// 去重
ports := removeDuplicates(reg.FindAllString(string(res), -1))
// netsh interface portproxy add v4tov4 listenport=80 connectaddress=172.17.83.208 connectport=80 listenaddress=* protocol=tcp
for _, port := range ports {
port = strings.TrimPrefix(port, ":")
if err := exec.Command("netsh", "interface", "portproxy", "add", "v4tov4", fmt.Sprintf("listenport=%s", port), fmt.Sprintf("connectaddress=%s", wslIP), fmt.Sprintf("connectport=%s", port), "listenaddress=*", "protocol=tcp").Run(); err != nil {
panic(err)
}
}
}
func removeDuplicates(elements []string) []string {
encountered := map[string]bool{}
result := []string{}
for v := range elements {
if encountered[elements[v]] == true {
// Do not add duplicate.
} else {
encountered[elements[v]] = true
result = append(result, elements[v])
}
}
return result
}
下载链接: https://pan.baidu.com/s/17DtEnzTtL3RjZa7egukIgA 提取码: qtad
- vbs 脚本
Set ws = WScript.CreateObject("WScript.Shell")
ws.run "D:\startwsl.exe -run=Ubuntu-18.04"
- startwsl.exe 设置以管理员身份运行此程序
- 将此 vbs 脚本添加到启动文件夹下,WIN+R 输入 shell:startup 回车
- 此电脑 --> 属性 --> 控制页板主页 --> 系统和安全 --> 更改用户账户控制设置 设置为 "从不通知"
- windows 防火墙开启入站规则或者直接关闭防火墙
- 设置 --> 更新和安全 -->Windows 安全中心 --> 防火墙和网络保护 --> 高级设置
- 入站规则 --> 新建规则 --> 端口 -->TCP, 特定本地端口 --> 允许连接