我的Windows10下的WSL的使用经历

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

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

首先什么是WSL

百度百科里面是这样介绍的: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服务管理远程主机,可以查看《Linux就该这么学(第2版)》第9章节的内容。

一开启WSL功能

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

分享两种启动WSL的方法

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

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


然后输入如下命令:

[Enable-WindowsOptionalFeature -Online -FeatureName VirtualMachinePlatform]

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



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

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


重启动计算机

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

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

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

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

二安装一个Linux系统

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

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

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

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

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

https://gh.gh2233.ml/https://github.com/mishamosher/CentOS-WSL/releases/download/7.9-2111/CentOS7.zip

https://github.91chi.fun/https://github.com/mishamosher/CentOS-WSL/releases/download/7.9-2111/CentOS7.zip

https://download.fastgit.org/mishamosher/CentOS-WSL/releases/download/7.9-2111/CentOS7.zip

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


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

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

三启动SSH服务

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

#!/bin/sh

# Start/stop/restart the secure shellserver:


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.sshdstop'.  'rc.sshd restart' kills only theparent sshd to"

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

   echo "         being cutoff.  If sshd has been upgraded, newconnections will now"

   echo "         use the newversion, 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


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

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

#允许root用户登录

PermitRootLogin yes

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

Port 12308

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

ListenAddress 0.0.0.0

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

chmod +x /etc/init.d/sshd

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

/etc/init.d/sshd start

ps -ef|grep ssh

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

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

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


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

有个报错需要注意下

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

通过网络很快搜索到解决方法:(//www.greatytc.com/p/f2b1370d87ac

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

解决方法如下:

ssh-keygen –A

或者

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

然后

重新启动sshd服务

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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,657评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,889评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,057评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,509评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,562评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,443评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,251评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,129评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,561评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,779评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,902评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,621评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,220评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,838评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,971评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,025评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,843评论 2 354

推荐阅读更多精彩内容