论为什么程序员都应该关注水星逆行——被 npm 5.4 一个 bug 折磨后有感

npm 5.4 安装某些 package 的时候报错 "Error: EPERM: operation not permitted"。

事件缘由与经过

这一节讲述我遇到 bug 的经过,如果你只关注水星逆行,可以直接跳到下一节。

2017年8月22日,npm 5.4.0 新版发布,此时正处于水星逆行期。

2017年9月4日,我把自己电脑的 npm 更新到这个最新版本 5.4.0。

2017年9月9日,我无论安装任何 npm 包,都报这个错:

我的项目路径>npm install
npm ERR! path 我的项目路径\node_modules\fsevents\node_modules\abbrev\package.json
npm ERR! code EPERM
npm ERR! errno -4048
npm ERR! syscall unlink
npm ERR! Error: EPERM: operation not permitted, unlink '我的项目路径\node_modules\fsevents\node_modules\abbrev\package.json'
npm ERR!     at Error (native)
npm ERR!  { Error: EPERM: operation not permitted, unlink '我的项目路径\node_modules\fsevents\node_modules\abbrev\package.json'
npm ERR!     at Error (native)
npm ERR!   stack: 'Error: EPERM: operation not permitted, unlink \'我的项目路径\\node_modules\\fsevents\\node_modules\\abbrev\\package.json\'\n    at Error (native)',
npm ERR!   errno: -4048,
npm ERR!   code: 'EPERM',
npm ERR!   syscall: 'unlink',
npm ERR!   path: '我的项目路径\\node_modules\\fsevents\\node_modules\\abbrev\\package.json' }
npm ERR!
npm ERR! Please try running this command again as root/Administrator.

npm ERR! A complete log of this run can be found in:
npm ERR!     我的系统路径\AppData\Roaming\npm-cache\_logs\2017-09-09T16_08_04_103Z-debug.log

于是我请教万能的404网站,发现这是 npm 5.4.0 的 bug。(Issue 传送门)

论为什么程序员都应该关注水星逆行——被 npm 5.4 一个 bug 折磨后有感_第1张图片
2017年9月1日曾被提交issue

幸运的是,Issue 里面已经提供了解决方案,这个 Issue 也已经被关闭。

论为什么程序员都应该关注水星逆行——被 npm 5.4 一个 bug 折磨后有感_第2张图片
这个 Issue 是5小时前关闭的,还很新鲜还没发霉

Issue 太长,解决方案隐藏很深。于是这里附上解决方案吧:

论为什么程序员都应该关注水星逆行——被 npm 5.4 一个 bug 折磨后有感_第3张图片
解决方案
  1. 删除项目中的整个儿 node_modules
  2. 把文件 package-lock.json 改名为 yarn.lock
  3. 运行命令 npm cache clear --force
  4. 把 npm 更新到版本 5.4.1:npm i -g [email protected]
  5. 用选项 --no-optionalnode_modules 装回来:npm install --no-optional
  6. 装其他新的 npm 包的时候,建议也加入选项 --no-optional

程序员是水星逆行的重灾人员

引用一段百度百科的原话:

水星墨丘利是罗马神话中的信使之神,负责所有信息的传递和交流,因此水逆时期通常是文书错误、信息丢失、机械故障、交通干扰以及各类细节相关问题频发的时段。

既然水星负责信息、机械、电,而我们程序员又处于一个与信息、机器、电的关系非常非常非常密切的行业当中,水星逆行对我们的影响无疑是比别的行业要严重一点的。

这回 npm 5.4 的 bug 就是一个例子。

另外一个例子是 iPhone 7 和 iOS 10。我记得这俩的发布日期是去年(2016年)的9月吧,也正处于水星逆行期间。当时我很明智地坚决不换手机,手上的 iPhone 6s+ 坚持用着 iOS 9 用到了今年(2017年)的3月。我记得当时身边换了 iPhone7 的朋友似乎都对这新手机不太爽(具体哪里不爽忘记了),而当时的 iOS 10 也是有电量的问题(耗电快了、剩20%电量就自动关机等)。

程序员如何应对水星逆行?

以下是我的个人经验:

  • 尽量避免在水星逆行期间发布上线,无法推迟的话,就小心谨慎,多检查几遍代码,避免出错。
  • 像 npm 和 iOS 之类,若是在水星逆行期间发布的,就先收起自己的好奇心,静静地看看别人的使用反馈,确保没人抱怨了才更新。
  • 水星逆行期间,与产品同学pk项目排期时,尽量多给自己争取一点缓冲时间,防止开发过程中出现意外bug。

这个app很值得大家学习:

论为什么程序员都应该关注水星逆行——被 npm 5.4 一个 bug 折磨后有感_第4张图片
去年某个app的更新版本

水星逆行每年有3次,每次大约20天左右。其实水星逆行是常见的天文现象,在占星学中也只是影响一些琐碎的事,但是若不对小事多加关注,就很容易踉成大事。

水星逆行具体在什么时候?这问题用不着问我啊,程序员请找万能的404,其他童鞋请找度娘。

你可能感兴趣的:(论为什么程序员都应该关注水星逆行——被 npm 5.4 一个 bug 折磨后有感)