wsl-windows下具有真实质感的linux环境
磕叨
有幸入到一个规模不算小的公司,算是对走弯路的过往的一个终结,慢慢适应吧。
新公司已上市,相比小公司,规矩比较多,现在要磕到的一条就是不能自带吃饭的家伙(macbook),只能用公司配的(windows),新来的员工不好意思申请公司配macbook,而且,假设我是leader,我大概率也不会批的。
但是从大学过啦到现在,我的工作环境基本都是 *nix ,最开始是Ubuntu,到Gentoo,再到现在用macbook,开发工作生活都可以是得心应手了,突然用回win是很是不习惯。
最开始,想的是cygwin(相类似的方案是MinGW64),cygwin上手很快,过一段时间后发现cygwin并不真的*nix,最明显就是当开发的程序需要根据执行环境区分win、linux的时候,往往有意外发生,执行的脚本以为自己是linux,通过exec调用执行的程序自始至终认为自己是win。
那就试试另一个方案--wsl。可惜wsl2走了歪路,不然也是好选择。
深入了解
wsl(Windows Subsystem for Linux)本质是对在win的内核层上模拟一层POSIX系统调用,让上层的基础库(例如最主要的C库),以及一些与win环境衔接的组件,例如wsl下的linux的共享socket地址空间等(当然也有不好的地方,我感受到最不友好的,有基于/proc文件系统的管理工具几乎全部失效了,还有winT的askManager里wsl进程与win自身的进程混到一起了)
当然还有另一个硬伤,那就是X环境,经过配置后他也是能完美工作的,但是要花狠多心思。
小试牛刀
step1
step2
step2.1
重启(忘记是不是必要的,但是对于win,重启是个好操作)
step3
安装wsl环境,你可以去Window Store上搜到,但是和谐的国度内似乎在线安装是装不上的,庆幸可以直接下载安装。主要的镜像(官方还是按社区的叫法把他们称作发行版)在微软的文档里 https://docs.microsoft.com/en-us/windows/wsl/install-manual 。github上有很多大神贡献出非常多优秀的wsl项目,有时间有心思可以自己玩玩,例如玩玩Arch的wsl发行版体验下滚动更新也好啊。
这里用的ubuntu-18.04 https://aka.ms/wsl-ubuntu-1804
打开PowerShell,切换到下载的appx文件(就是刚刚下载到的wsl发行版)所在的目录, 执行
Add-AppxPackage .\app_name.appx
等待安装完成,后桌面上会多一个 Ubuntu18.04.exe 的快捷方式,双击它(如果没有,打开你的cmd,输入bash,回车),就能能成功进入你的第一个wsl,初始会要求你输入一个用户名和密码的,记着他。而后各种命令环境都是非常熟悉。摸索了一下bash,大部分命令都是能正常运行,除了少数跟网络相关的,原因前面说到了。
基础环境准备
默认的shell环境
要在和谐的环境下愉快的工作,切换源是必须的。修改/etc/apt/sources.list,替换为以下内容
#------------------------------------------------------------------------------## OFFICIAL UBUNTU REPOS ##------------------------------------------------------------------------------####### Ubuntu Main Reposdeb mirror://mirrors.ubuntu.com/mirrors.txt bionic main restricted universe multiversedeb-src mirror://mirrors.ubuntu.com/mirrors.txt bionic main restricted universe multiverse###### Ubuntu Update Reposdeb mirror://mirrors.ubuntu.com/mirrors.txt bionic-security main restricted universe multiversedeb mirror://mirrors.ubuntu.com/mirrors.txt bionic-updates main restricted universe multiversedeb mirror://mirrors.ubuntu.com/mirrors.txt bionic-backports main restricted universe multiversedeb-src mirror://mirrors.ubuntu.com/mirrors.txt bionic-security main restricted universe multiversedeb-src mirror://mirrors.ubuntu.com/mirrors.txt bionic-updates main restricted universe multiversedeb-src mirror://mirrors.ubuntu.com/mirrors.txt bionic-backports main restricted universe multiverse
完成后执行
sudo apt-get update && sudo apt-get upgrade
更新发行版中的包
安装一些基础的包如vim等
sudo apt-get install -y vim mlocate tree git
调整配置更适合在win下工作
更友好的shell -- 更改配色为gentoo的配色 (文件在这 https://gitweb.gentoo.org/repo/gentoo.git/tree/app-shells/bash/files/bashrc ),找个地方放好,例如我的
/etc/bash.color.gentoo.bashrc
,然后在~/.bashrc
,. /etc/bash.color.gentoo.bashrcexport EDITOR=/usr/bin/vim
wsl下无法更改hostname,丑,那就该PS1变量好了。
vim ~/.bashrc
,找到PS1变量的定义,把\h
以及\H
换为你喜欢的,例如我的如图,以及上面的这个gentoo.bashrc文件,也有个PS1变量,一起改了win文件权限,默认的win的盘会挂载到
/mnt
目录下,但是默认的权限确实777,辣眼啊,网传在~/.bashrc
中加入umask 022
,但是win下新建文件的时候,或使用基于linux桌面的IDE创建文件的时候,权限又会编程 777 或 755。后找到官方的方案,在/etc/wsl.conf
配置文件中写入如下配置,文件不存在则新增一个[automount]enabled = trueroot = /mnt/options = "metadata,dmask=022,fmask=133"mountFsTab = false
保存后重启wsl, 重启wsl的方法为在cmd 中执行
net stop LxssManager
完成后再执行net start LxssManager
即可。
(因为机子还有CygWin环境,我发现CygWIn操作的文件和文件夹的权限的掩码是不同的,平时没什么特别的问题,但是git会追踪权限的变化,导致冲突,只能着重用一个了)自启动脚本:自启动好像没什么好办法,前辈们的方法几乎都是写个vbs脚本放到
win-开始-启动
的文件夹里(快捷找到这个文件夹 按键win+r 输入shell:startup系统会自动打开一个目录,就是他)。
此文件夹下创建wsl.ubunti.bonic.init.vbs,内容填入Set ws = WScript.CreateObject("WScript.Shell")ws.run "C:\Windows\System32\bash.exe -c 'sudo /etc/rc.local'",0
然后再bash内执行
sudo vim /etc/sudoers.d/rc-local
,内容填入jiefzz * = (root) NOPASSWD: /etc/rc.local
把我的用户名
jiefzz
换为你的,记得做这步,不然,这个脚本执行就会停在输入密码的这个位置上。然后编辑/etc/rc.local
,放入默认的两个服务#!/bin/bashservice dbus startservice ssh start
然后你在
/etc/rc.local
后面加入你想执行的命令,只要不要阻塞就行(本码农测试,企图在命令后加 & ,让命令在后台执行还是有一些问题,最终选择用supervisord作任务管理了),最后chmod +x /etc/rc.local
。注意的事: 这个vbs脚本在你每次手动重启(注意,是手动重启)wsl子系统的时候,都需要手动双机这个vbs才能让自启动的脚本运行
愉快的控制台
控制台方案我推荐两个可以选,一个 https://hyper.is (巨好看,可以在win上实现半透明呢~)
hyper毕竟在发展中,偶然有小bug,问题不大,而且hyper的主题特效非常酷炫,详见官网。另一个就是MobaXterm,全功能的终端工具,不多说。
我就暂时用着MobaXterm,有时间好好折磨hyper。
linux本该有的质感
进程管理
wsl的根进程是巨硬家自己提供的init程序(非脚本,不好把控),进入bash后,也可以用发行吧提供的 service
命令管理apt安装下来的服务,但是管理上都是差强人意。质感上比systemd差得远。
经过多次尝试,还是决定使用supervisord作管理,因为对他熟悉,操作简单。我们直接 sudo apt-get install supervisor
即可安装。安装完成都对配置做一些小的修改,以便我们的默认用户就可以管理进程,不用每次都root(对安全过敏的话,还是每次都sudo吧)。
$ vim /etc/supervisor/supervisord.conf...[unix_heep_server]file=/var/run/supervisor.sockchmod=0700chown=jiefzz:jiefzz ; 这个位置换为你的用户名...[include]files = /server/conf/supervisor/conf.d/*.conf ; 改为一个你好备份的地址
最后 /var/run/supervisor.sock
所在的文件夹,只有root有访问权限,执行 setfacl -m user:jiefzz:rwx /var/run
给我们的默认用户加权限。
初始化时启动supervisord: 把上面说的 /etc/rc.local
更改为如下内容,即可在WSL启动时启动supervisor。
#!/bin/bashservice dbus startexec /usr/bin/supervisord -c /etc/supervisor/supervisord.conf
进程树可以用 top
命令的深林模式来查看,也可以用 sudo apt-get install tree
提供的 pstree
命令.
基础进程
- cron
- sshd
开发环境
- nginx
- java、maven
- mysql
- mongodb
- 酸酸r(搜索技术网文,少不了他)
开启cron后,计划一下很有必要的任务
$ sudo crontab -e## locate查找文件速度极快,但是需要*/10 * * * * /usr/bin/updatedb
桌面环境
未完待续 。。。
(2020-03-21更新)
桌面下问题比较多,多是因为现在大部分DE(desktop environment)的基础组件上都选用了systemd,勉强跑得起来的xfce4,也有很多不完善的地方,跑起来没问题,美化后也很好看,工作起来不太顺手。
另外看到不少需要启动chrome headless模式的程序可能也有问题,node或python调用一个浏览器引擎这种,可能跑不掉还是得回到win上去,幸好跑java这些还是妥妥的。