有没有熟悉 node 的朋友, Linux 上编译 node16 快 12 小时了,咋这么慢。。。

2021-12-02 00:54:01 +08:00
 LeeReamond

如题,从开始的时候感觉正常到现在怀疑自己是否哪里搞错了,一直编译,cpu 一直占用 100%(单核虚拟机)

具体安装方法就是从官网上下个源码,然后解压,configure ,make && make install.

编译过程中除了 CPU 占用高,内存占用也挺高的,不过 1G+swap 应该还扛得住,问题就是编译咋这么慢。而且编译之前也没要求装啥依赖之类的,像 python 编译起码还要装个 build-essential ,我是不是哪里做错了?

10394 次点击
所在节点    Node.js
32 条回复
xiadong1994
2021-12-02 03:23:03 +08:00
单核 1G ,emmmm……不是很了解 node 的编译,但是这个配置是不是有点太低了。还有 build 一般还挺吃磁盘 IO 的。
felixcode
2021-12-02 03:46:02 +08:00
单核肯定慢,不过影响更大的是内存不够用了 swap ,然后磁盘 io 性能还特别低。
LeeReamond
2021-12-02 04:27:59 +08:00
@felixcode
@xiadong1994 我观察任务管理器了,没有走 swp 卡 io 的情况,而且 ssd 读写速度都是 500MB/S 的,卡了也不会像机械硬盘那样。问题在于它只是个 node ,我这又不是在编译宇宙第一 IDE....安装包大小才几十 MB ,编译跳一下几十 KB 总有吧。。
xiadong1994
2021-12-02 04:42:51 +08:00
应该就是单纯的慢,我在工作站上 make 了一下大概 5min 跑完
thedrwu
2021-12-02 05:27:54 +08:00
估计 1G 内存连 linker 都跑不起来
unnamedhao
2021-12-02 07:47:50 +08:00
比慢?试试装 xcode ,单纯的安装
encro
2021-12-02 09:16:39 +08:00
1G 铁定慢,有什么想不开自己编译 node 呢。
arischow
2021-12-02 09:33:35 +08:00
1G 连 npm build 公司项目都可能 oom
max1233
2021-12-02 09:51:22 +08:00
12 个小时太夸张,1c2g 的小鸡都比这个快,编译 node 大概用了 15 分钟。话说为啥要编译呢 nvm 不香吗
hronro
2021-12-02 10:20:50 +08:00
会不会是连 v8 一起在编译?如果是的话那很正常
libook
2021-12-02 10:24:35 +08:00
都是单核,也是有主频高低的,另外如果是虚拟机、容器之类的还会有其他开销。

CPU 不够会慢,内存不够会崩,用 Swap 也会慢(即便用最快的 NVMe SSD 也远不及物理内存速度)。

拿 Chromium 的编译来作参考,我找到了去年的一篇文章: https://textslashplain.com/2020/02/02/my-new-chromium-build-pc/
16 核心 32 线程、64GB 内存、Intel Optane 905P NVMe SSD ,编译 Chromium 花了 53 分钟。
skinny
2021-12-02 11:30:50 +08:00
当年很多人说 Qt 编译非常慢,随便六七个小时,我当时在我的笔记本下载编译也顶多一个小时,你这个慢得太夸张了
2i2Re2PLMaDnghL
2021-12-02 12:50:34 +08:00
make 有命令输出的
如果一直有输出,那应该不是大问题,就是慢罢了
如果没有,看下最后一条是啥卡住了,然后去提 Issue 问
geniux
2021-12-02 12:53:33 +08:00
用二进制,不用编译。
12101111
2021-12-02 12:54:31 +08:00
8 核+16G 内存+源码在 tmpfs 里, 用 Clang+ld.lld 开 LTO ,半个多小时
你这个肯定是内存太小,swap 太严重了
bootvue
2021-12-02 13:01:33 +08:00
make -j 核心
rm0gang0rf
2021-12-02 15:20:33 +08:00
啥玩意也没这么慢。。1g 的没遇到过
vanton
2021-12-02 15:24:49 +08:00
内存太小,编译需要大量内存,你这 1G 就是瓶颈。
内存对于编译速度的影响是指数级别的,你内存加大 1 倍速度提升可能有 10 倍。
shiny
2021-12-02 15:25:56 +08:00
那有点离谱,以前在树莓派上编译都没花这么久
tulongtou
2021-12-02 15:36:55 +08:00
你也没有改源码,为什么要自己编译?直接下载二进制的运行不好么

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/819425

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX