为什么从cygwin迁移到msys2

习惯Linux后,再使用Windows的话,cygwin基本是必须的。但cygwin有一些痛点:

  1. 没有一个好用的包管理工具,无论是官方的setup.exe,还是第三方的几个apt-cyg,都存在使用不方便和功能不全的问题:

    • setup.exe选包很累人
    • apt-cyg和它的依赖得额外安装
    • cygwin的已安装软件数据库不区分是直接安装的还是被依赖的包,一旦装上想等卸载就只能自己手动分辨了
    • apt-cyg不支持软件升级操作,我自己加上了这个功能(goreliu/apt-cyg),虽然基本能用,但还是存在一些问题
  2. cygwin的软件打包方式不方便,并且为官方软件仓库提交新的包需要走加邮件列表、发邮件、确认、上传等诸多流程
  3. cygwin里不少软件的版本还是比较老的,比如git还是2.1.4版本的,升级缓慢(一个好消息是python和ruby最近几天升级到最新版本了,之前还是python 2.7.8/3.2.2、ruby 2.0.0,盼了好久)

而msys2基本上解决了这些问题:

  1. 使用从archlinux移植过来的pacman,功能完整,使用方便
  2. PKGBUILD好写,用过archlinux的话无学习成本,为官方源提交新包可以直接在github发PR
  3. msys2里的软件总体是要比cygwin新的(一个特例,最近cygwin的ruby升级到了最新的2.2,而msys2的还是2.1)

迁移的麻烦

我几个月前就在垂涎msys2,但因为几个麻烦的问题,每次都作罢:

  1. cygwin是可以使用acl选项挂载文件系统的,这种情况下chmod基本可用(虽然也有些问题),而msys2只能使用noacl选项挂载,chmod基本无法工作(只能修改第一个w),每个用户都有文件的读权限,是否有执行权限根据文件扩展名和内容决定。直接的影响就是使用git时无法使本地文件权限和远程的一致。
  2. 我使用的一些软件cygwin里有,而msys2里没有,比如w3m、dig、atool、bvi、cygstart。
  3. 有些软件支持直接在cygwin编译,而在msys2编译的话需要打patch。

之前主要是阻塞在第1个问题上了,查了好久如何开启acl,无果。今天突然想到是否可以让git忽略本机权限,果然有方法:

git config core.filemode false

另外还有.ssh目录无法修改成700的麻烦,好在我不需要在msys2开sshd,可以不考虑这个。那么权限的文件基本就没有了。

第2个问题就相对好处理了,自己编译打包了bviplus、atool、w3m、cygutils(里边有cygstart)等,因为之前在archlinux就经常自己打包,轻车熟路,PKGBUILD见https://github.com/goreliu/my-MSYS2-Packages。Dig不好编译,但有现成的可以下载

第3个问题只是稍微麻烦些,可以写个脚本搞定,基本不用考虑。

折腾了一下午,终于迁移了过了,删掉了cygwin。

步骤

  1. 官网下载最新的安装包,安装到c:msys64。
  2. 将之前cygwin的home目录直接替换到msys64/home
  3. mkpasswd > /etc/passwd; mkgroup > /etc/group,和cygwin里一样
  4. 注释掉/etc/fstab中的那一行,保留/cygdrive目录,以和cygwin一致(可选)
  5. 修改/etc/etc/pacman.d/mirrorlist.*,改成国内地址,如http://mirror.bit.edu.cn/msys2/
  6. 使用pacman安装需要的软件
  7. 在文件浏览器的邮件添加Open MSYS2 here的菜单:

    Windows Registry Editor Version 5.00

    [HKEY_CLASSES_ROOTDirectoryBackgroundshellopen_msys2]
    @="Open MSYS2 here"

    [HKEY_CLASSES_ROOTDirectoryBackgroundshellopen_msys2command]
    @="c:\msys64\usr\bin\mintty.exe /bin/sh -lc 'cd "$(cygpath "%V")"; exec zsh'"

    [HKEY_CLASSES_ROOTFoldershellopen_msys2]
    @="Open MSYS2 here"

    [HKEY_CLASSES_ROOTFoldershellopen_msys2command]
    @="c:\msys64\usr\bin\mintty.exe /bin/sh -lc 'cd "$(cygpath "%V")"; exec zsh'"

  8. 创建指向C:\msys64\usr\bin\mintty.exe /usr/bin/zsh --login的快捷方式,并绑定快捷键
  9. 设置export MSYS="winsymlinks:lnk"关键变量,不然打软连直接变成了复制
  10. 在需要忽略本地文件权限的git repo目录运行git config core.filemode false
  11. isc.org下载windows版本的bind,包含host、dig等命令
  12. git clone git@github.com:goreliu/my-MSYS2-Packages.git,进入需要的目录,运行 makepkgpacman -U xxx.tar.xz安装自己打的包。

然后环境就和之前的cygwin没有什么区别了。