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这些还是妥妥的。

(0)

相关推荐