我的Windows10下的WSL的使用经历

微软每年都会举办 Build 开发者大会,近年来越来越受关注的 子系统 Windows Subsystem for Linux ( WSL )已经很完善了,我抱着体验一把的心态,也来使用一下这个功能。

各位新手 Linux 朋友们, 有没有想过怎么在 W indows 下面使用 Linux ,下面我来通过自己的实际操作,分享一遍自己的 Windows10 下的 WSL 的使用经历。

首先什么是 W SL

百度百科里面是这样介绍的: Windows Subsystem for Linux (简称 WSL )适用于 Windows 的 Linux 子系统。 也许刚刚接触 Linux 的新手会觉得奇怪, Linux 不是单独的系统吗?比如我们学习和考试认证的都是 Redhat 、 Ubuntu 、 Centos 等。 为什么 Windows 会有一个 Linux 的子系统呢?其实此子系统起源于命运多舛的 Astoria 项目,其目的是允许 Android 应用运行在 Windows 10 Mobile 上。此功能组件从 Windows 10 Insider Preview build 14316 开始可用。后来到了 2022 年 9 月 22 日,微软发布了 Windows 11/10 的 Linux 子系统新预览版,微软宣布从该版本开始, WSL 已支持 systemd 。最新的正式版于 2022 年 11 月 16 日,微软 Win11/10 Linux 子系统 WSL 1.0.0 发布

操作 Linux 的过程中常用的命令和如何使用 ssh 服务管理远程主机,可以查看 第 9 章节的内容。

一   开启 WSL 功能

首先是你要使用 Windows 10 2004 以上版本。或者你理解为要是 2 022 年 9 月份以后的版本。我写本文的时间是 2 022 年 1 1 月,更新了最新的微软 1 1 月累计更新包。

分享两种启动 W SL 的方法

方法 1 :通过命令行启动 W SL 。

点击右下角 W IN 开始 - 右键 - Windows PowerShell( 管理员 )   以管理员身份运行。

然后输入如下命令:

[ Enable-WindowsOptionalFeature -Online -FeatureName VirtualMachinePlatform ]

看到如下就表示虚拟平台正在启动。

虚拟平台开启后,接着在命令行中输入以下命令开始 Linux 子系统:

[ Enable-WindowsOptionalFeature -Online -FeatureName Microsoft-Windows-Subsystem-Linux ]

重启动计算机

方法 2 :当然你也有第二种启动的方法,不用敲命令这么麻烦 。

开机进入 - 控制面板 - 程序 - 找到 启动或关闭 Windows 功能

请在勾选框中勾选 - 适用于 Linux 的 Windows 子系统

这个时候系统也会要求你重启动计算机。

二   安装一个 Linux 系统

功能开启以后,这个时候你可以选择的有两种方法:

1.  通过 打开电脑上微软应用商店,在搜索框中输入 Linux ,然后在出来结果中你可以看到很多发行版的 Linux 。当前通过这种方法只有一个 Ubuntu 的下载。

获取该版本,然后安装就可以了。

这个方法看上去简单,我一般不推荐也不愿意折腾。这是因为很多版本的 W indows10 无法或者不愿意通过微软应用商店下来更新。

1.  直接手动下载一个安装包 ,这个方法是我认为最简单的。我在网上找到了如下几个下载连接供大家使用:

下载完成以后,直接运行 Cent OS7.exe 安装就可以了。

安装的过程请看上图,按照画面提示操作即可。

打开开始 - 选择 Windows PowerShell 运行看一下,这就是我们 L inux 子系统了。

三   启动 S SH 服务

     为什么要启动 S SH 服务器,这个不用我多说了把。使用 Linux 的时候,因为大部分用户一般都是使用 S SH 连接到服务器上,所以上来就直接启动 systemctl 失败。结果后来上网查资料才发现,原来 W SL 无法使用 systemctl ,正好使用网络找到了一个写好的脚本分享给大家。

#!/bin/sh

1. Start/stop/restart the secure shell server:

 

sshd_start() {

  # Create host keys if needed.

  if [ ! -r /etc/ssh/ssh_host_key ]; then

    /usr/bin/ssh-keygen -t rsa1 -f /etc/ssh/ssh_host_key -N ''

  fi

  if [ ! -f /etc/ssh/ssh_host_dsa_key ]; then

    /usr/bin/ssh-keygen -t dsa -f /etc/ssh/ssh_host_dsa_key -N ''

  fi

  if [ ! -f /etc/ssh/ssh_host_rsa_key ]; then

    /usr/bin/ssh-keygen -t rsa -f /etc/ssh/ssh_host_rsa_key -N ''

  fi

  if [ ! -f /etc/ssh/ssh_host_rsa_key ]; then

    /usr/bin/ssh-keygen -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key-N ''

  fi

  if [ ! -f /etc/ssh/ssh_host_rsa_key ]; then

    /usr/bin/ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ed25519_key-N ''

  fi

  /usr/sbin/sshd -f /etc/ssh/sshd_config

}

 

sshd_stop() {

  killall sshd

}

 

sshd_restart() {

  if [ -r /var/run/sshd.pid ]; then

    echo "WARNING: killing listener process only.  To kill every sshd process, you must"

    echo "         use 'rc.sshd stop'.  'rc.sshd restart' kills only the parent sshd to"

    echo "         allow an admin logged in through sshd to use 'rc.sshd restart' without"

    echo "         being cut off.  If sshd has been upgraded, new connections will now"

    echo "         use the new version, which should be a safe enough approach."

    kill `cat /var/run/sshd.pid`

  else

    killall sshd

  fi

  sleep 1

  sshd_start

}

 

case "$1" in

'start')

  sshd_start

  ;;

'stop')

  sshd_stop

  ;;

'restart')

  sshd_restart

  ;;

*)

  echo "usage $0 start|stop|restart"

esac

 

编辑这段 S HELL 和以往一样,记得一定要保存 。

接下来就是修改 sshd 的服务配置 vi /etc/ssh/sshd_config

1. 允许 root 用户登录

PermitRootLogin yes

1. 服务端口,为了不和 windows 及其它 WSL 子系统冲突,手动指定一个

Port 12308

1. 监听地址,如果需要远程机器连接

ListenAddress 0.0.0.0

到这一步先不要换,记得提升自己的用户权限,

chmod +x /etc/init.d/sshd

启动 sshd, 查看服务已经启动

/etc/init.d/sshd start

ps -ef|grep ssh

启动的过程会弹出防火墙的提示,这个时候点击允许

这样一切顺利的话,你可以通过 W indows 打开运行 命令行模式 cmd

输入 netstat -ano|findstr "12308", 查看端口,发现已经启动。

接下来就是 就可以配合 vscode ,通过远程连接到 Windows 下的 Centos 进行编译。

有个报错需要注意下

如果启动出现报错 error: Could not load host key: /etc/ssh/ssh_host_ed25519_key

通过网络很快搜索到解决方法:( )

这是因为新版的 opensshd 中添加了 ed25519 做签名验证,而之前系统里没这个算法的证书。生成一下就好了

解决方法如下:

ssh-keygen –A

或者

ssh-keygen -t ed25519 -f /etc/ssh/ssh_host_ED25519_key

然后

重新启动sshd 服务

以上就是我运行 Windows 子系统 W SL 的操作步骤,当中也有些不足,希望能够在 Linux 的学习中帮助大家。