centos7安装node-v18版本

news2024/9/20 4:40:52

背景#

背景就是上一篇文章提到的,部署gitbook这个文档中心的话,是需要先安装node,然后,如果你的node版本过高的话,一般会报错,此时,网上很多文章就是降node版本解决,但其实用高版本也是有办法的,只是麻烦点,要改改代码;但是,我下载了高版本的node安装时,发现在centos7上还装不了,可谓一波未平一波又起。

报错的nodejs版本:v18,我这边具体的是node-v18.18.2-linux-x64.tar.xz

服务器版本是centos 7.6,centos 7.9(两个都试了)

下面这个问题可以看下:

https://stackoverflow.com/questions/72571235/can-i-install-node-js-18-on-centos-7-and-do-i-need-python-3-install-too#:~:text=Starting v18%2C Node.,due to glibc version incompatibility.

image-20231024213204595

NodeJS 18 revert to building on CentOS 7, RHEL 7, Ubuntu Bionic 18.04, other other LTS distros · Issue #43246 · nodejs/node · GitHub

吵得还是挺厉害。我觉得也是比较坑的是,下载的时候,文档也没个提示,比如是否在centos7上可用,等到弄下来搞出一堆问题了上网去找才知道版本不兼容。

下面具体说下这个问题。

问题原因分析#

tar -xvf node-v18.18.2-linux-x64.tar.xz cd node-v18.18.2-linux-x64/ [root@VM-0-6-centos node-v18.18.2-linux-x64]# bin/node bin/node: /lib64/libm.so.6: version `GLIBC_2.27' not found (required by bin/node) bin/node: /lib64/libc.so.6: version `GLIBC_2.25' not found (required by bin/node) bin/node: /lib64/libc.so.6: version `GLIBC_2.28' not found (required by bin/node) bin/node: /lib64/libstdc++.so.6: version `CXXABI_1.3.9' not found (required by bin/node) bin/node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found (required by bin/node) bin/node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by bin/node) 

这个报错,是这个意思,node在执行的时候,是依赖了一些动态库的,依赖了哪些呢:

  [root@VM-0-6-centos node-v18.18.2-linux-x64]# ldd bin/node linux-vdso.so.1 => (0x00007fff34927000) libdl.so.2 => /lib64/libdl.so.2 (0x00007fd57af20000) libstdc++.so.6 => /lib64/libstdc++.so.6 (0x00007fd57ac19000) libm.so.6 => /lib64/libm.so.6 (0x00007fd57a917000) libgcc_s.so.1 => /lib64/libgcc_s.so.1 (0x00007fd57a701000) libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fd57a4e5000) libc.so.6 => /lib64/libc.so.6 (0x00007fd57a117000) /lib64/ld-linux-x86-64.so.2 (0x00007fd57b124000) 

在 => 这个符号左侧,就是依赖的动态库名字,右侧,就是根据这个名字,在环境变量LD_LIBRARY_PATH指定的路径下查找,最终解析到的动态库全路径。

那我们再来看第一行报错:

[root@VM-0-6-centos node-v18.18.2-linux-x64]# bin/node bin/node: /lib64/libm.so.6: version `GLIBC_2.27' not found (required by bin/node) 

/lib64/libm.so.6这个是全路径,看起来找到了,但是还是报错,好像说要在GLIBC_2.27这个版本没找到。

我们可以这样,在执行ldd时打个详细日志:

[root@VM-0-6-centos]# ldd -v bin/node Version information: bin/node: ... libm.so.6 (GLIBC_2.27) => not found libm.so.6 (GLIBC_2.2.5) => /lib64/libm.so.6 

看起来,它是找libm.so.6(GLIBC_2.27)没找到,但找到了libm.so.6 (GLIBC_2.2.5)。

这块其实是这样,内核提供给用户的是系统调用(system call),但是,在我们编写c语言代码时,一般不是直接去调用这些系统调用,而是会include一些头文件,如include <stdio.h>,这些头文件算是接口,这些接口包括其实现,最终编译成二进制打成一个库,供用户使用。最早是标准的libc库,后来逐渐被glibc这个取代,glibc是GNU发布的libc库,官网:The GNU C Library- GNU Project - Free Software Foundation

这个glibc库,比如在我的centos7.6上,到底在啥位置呢?

我先看了下本机的glibc版本是2.17:

https://lindevs.com/check-glibc-version-in-linux 方法1: [root@VM-0-6-centos lib64]# ldd --version ldd (GNU libc) 2.17 方法2: [root@VM-0-6-centos lib64]# ldd `which cat` | grep libc libc.so.6 => /lib64/libc.so.6 (0x00007f27331c8000) [root@VM-0-6-centos lib64]# /lib64/libc.so.6 GNU C Library (GNU libc) stable release version 2.17, by Roland McGrath et al. 

glibc一般也是有rpm包的,我在这个网站上找到了2.17版本的x86-64的glibc的包:

glibc-2.17-326.el7_9.x86_64 RPM

可以看到,它其实包含了非常多文件,其中就有/lib64/libm.so.6:

image-20231025220044115

那我意思其实就是,/lib64/libm.so.6就是glibc的一部分,那这个2.17版本的glibc,包含的/lib64/libm.so.6报的这个错到底啥意思啊?

[root@VM-0-6-centos]# ldd -v bin/node Version information: bin/node: ... libm.so.6 (GLIBC_2.27) => not found libm.so.6 (GLIBC_2.2.5) => /lib64/libm.so.6 

我找到了一个绝好的回答:

shared library - What do the multiple GLIBC versions mean in the output of ldd? - Unix & Linux Stack Exchange

GLIBC_..., GLIBCXX_... etc. are version symbols, which are used in some libraries (including the GNU C library and the GCC libraries) to identify required versions and to manage backward compatibility. A binary (executable or library) will usually end up requiring multiple versions, based on the symbols it really uses from the target library. To satisfy the requirements of a given binary, you need to provide a library which supports all the required versions — i.e. a library matching at least the highest version symbol in the list of requirements. 

翻译过来是,GLIBC_...GLIBCXX_...是版本符号,在某些库(包括GNU C库和GCC库)中使用它们来标识所需的版本并管理向后兼容性。二进制文件(可执行文件或库)通常最终需要多个版本,具体取决于它实际使用的目标库中的符号。为了满足给定二进制文件的要求,您需要提供一个支持所有所需版本的库 -至少匹配要求列表中最高版本符号的库。

The reason multiple versions can end up being required, is that each imported object (function etc.) can have a version, and a given binary can link against multiple versions across all the functions it uses. 

翻译:最终可能需要多个版本的原因是每个导入的对象(函数等)都可以有一个版本,并且给定的二进制文件可以链接到它使用的所有函数的多个版本。

我这里也只截取了一部分,大家还是去看原文吧,反正意思就是,比如node这个程序,它就是会用到/lib64/libm.so.6里面不同version symbol的函数,你需要做的,就是满足它,否则,它就报错。

怎么满足它呢,就是把/lib64/libm.so.6的版本升上去,直到包含GLIBC_2.27这个version symbol。

那怎么才能升/lib64/libm.so.6上去呢,那它既然是glibc的一部分,自然是只能整体升级glibc到指定版本,比如这里的GLIBC_2.27

解决-升级GLIBC#

这里参考了文章:

【我用鲲鹏做开发】CentOS7安装NodeJS18

跟我遇到的坑差不多。文章里1、安装编译环境devtoolset-8那部分应该不需要特别关注,我觉得也不用操作,因为这种偷懒方式安装的gcc,是解决不了node安装报错的问题的,往下看就知道了。

开始升级glibc,值得注意的是,大家最好是虚拟机、个人的云主机先玩一玩,不要拿着有其他人在用的环境搞这些,很容易把机器彻底搞到不能收场的地步;玩之前也记得备份,比如先复制一个虚拟机出去

慢的话,可以自己手动下载再上传 wget https://ftp.gnu.org/gnu/glibc/glibc-2.28.tar.gz --no-check-certificate tar -xzvf glibc-2.28.tar.gz cd glibc-2.28 mkdir build && cd build (一定要单独建个文件夹来build) 

在编译开始前,修改 scripts/test-installation.pl 128行,增加 && $name ne "nss_test2" ,以避免编译错误 nss_test2报错,反正就是照着加一行。

接下来,是configure命令,尤其注意加--enable-obsolete-nsl,解决undefined reference to '_nsl_default_nss@GLIBC_PRIVATE',其他选项用他文章的也行,我的那个命令搞丢了(虚拟机后来搞别的搞坏了)

../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin --enable-obsolete-nsl 

然后就是:

make 或者 make -j4 (4个线程并发跑) 我记得我这边大概耗时半小时或一小时内,忘了,还是虚拟机这种性能差的 make install 检查里面的version symbol: strings /lib64/libc.so.6 | grep GLIBC 

解决gcc问题--升级gcc#

解决上面的问题后,继续执行node,还是报错,大概如下:

bin/node: /lib64/libstdc++.so.6: version `CXXABI_1.3.9' not found (required by bin/node) bin/node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found (required by bin/node) bin/node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by bin/node) 
查看这个里面的symbol version,最新到1.3.7,不满足1.3.9的要求: [root@VM-0-6-centos node-v18.18.2-linux-x64]# strings /lib64/libstdc++.so.6 |grep CXXABI_ CXXABI_1.3 CXXABI_1.3.1 CXXABI_1.3.2 CXXABI_1.3.3 CXXABI_1.3.4 CXXABI_1.3.5 CXXABI_1.3.6 CXXABI_1.3.7 最新到3.4.19,不满足3.4.20和3.4.21的要求: [root@VM-0-6-centos node-v18.18.2-linux-x64]# strings /lib64/libstdc++.so.6 |grep GLIBCXX ... GLIBCXX_3.4.11 GLIBCXX_3.4.12 GLIBCXX_3.4.13 GLIBCXX_3.4.14 GLIBCXX_3.4.15 GLIBCXX_3.4.16 GLIBCXX_3.4.17 GLIBCXX_3.4.18 GLIBCXX_3.4.19 

按照官方文档来的:

InstallingGCC - GCC Wiki

安装gcc前,需要先安装依赖的gmp-devel mpfr-devel libmpc-devel,好多文章是说yum安装,我觉得也可以,但我就怕gcc版本和yum安装的这些依赖的版本不太匹配,建议还是按照如下方式来安装:

wget https://ftp.gnu.org/gnu/gcc/gcc-8.5.0/gcc-8.5.0.tar.gz --no-check-certificate cd gcc-8.5.0 ./contrib/download_prerequisites 

这一步就会去下载对应的源码,需要互联网:

[root@VM-0-6-centos gcc-8.5.0]# ./contrib/download_prerequisites 2023-10-22 15:40:49 URL: ftp://gcc.gnu.org/pub/gcc/infrastructure/gmp-6.1.0.tar.bz2 [2383840] -> "./gmp-6.1.0.tar.bz2" [1] 2023-10-22 15:42:05 URL: ftp://gcc.gnu.org/pub/gcc/infrastructure/mpfr-3.1.4.tar.bz2 [1279284] -> "./mpfr-3.1.4.tar.bz2" [1] 2023-10-22 15:42:42 URL: ftp://gcc.gnu.org/pub/gcc/infrastructure/mpc-1.0.3.tar.gz [669925] -> "./mpc-1.0.3.tar.gz" [1] 2023-10-22 15:44:31 URL: ftp://gcc.gnu.org/pub/gcc/infrastructure/isl-0.18.tar.bz2 [1658291] -> "./isl-0.18.tar.bz2" [1] gmp-6.1.0.tar.bz2: OK mpfr-3.1.4.tar.bz2: OK mpc-1.0.3.tar.gz: OK isl-0.18.tar.bz2: OK All prerequisites downloaded successfully. 

下完后,就保存到了当前目录下,几个tar包。

mkdir build cd build/ 我是不需要gcc支持编译go,需要的话,可以加上 ../configure --disable-multilib --enable-languages=c,c++ --prefix=$HOME/local 接下来就是make,我一开始求快,搞得是: nohup make -j4 2>&1 & 结果后面等了好久,报错了。。。抱着试试看心理,改成make,结果成功了 nohup make 2>&1 & tailf nohup.out make install export LD_LIBRARY_PATH=$HOME/local/lib64 

这里这个make,要执行很久很久,反正我的云主机是这样,1核2g,cpu一直是100%,跑了2个半小时:

image-20231025225356657

从4点20:

image-20231025225415970

跑到6点40了:

image-20231025225433610

搞完这些,再去用node,应该就没啥问题了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1316958.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【️如何理解面向对象和面向过程】

✅如何理解面向对象和面向过程&#xff1f; 典型理解✅扩展知识仓✅面向对象的三大基本特征✅封装✅继承✅多态 ✅为什么Java不支持多继承&#xff1f;✅菱形继承问题✅Java 8 中的多继承 ✅面向对象的五大基本原则&#xff1f; 典型理解 面向过程把问题分解成一个一个步骤&…

buuctf-Misc 题目解答分解85-87

85.[UTCTF2020]file header 下载完就是一个图片 &#xff0c;但是显示图片错误&#xff0c;提示文件头 没有 用010editor 打开 找一个png 文件&#xff0c;看一下它的头部 只需要修改前四个字节为 89 50 4E 47 即可 就能拿到flag utflag{3lit3_h4ck3r} 86.[WUSTCTF2020]gir…

蓝桥杯专题-真题版含答案-【三角螺旋阵】【干支记年法】【异或加密法】【金字塔】

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分…

v851s ssh搭建与使用

ssh 概述: 1. 用来远程登录的一种安全通道协议(常用于linux 、UNIX中); 2. 分为服务端和客户端: 1)服务端即openSSH ,一般属于目标开发板(linux中配置文件路径/etc/ssh/sshd_config); 2)客户端即登录端,常用工具:sercureCRT 、MobaXterm 、Putty等; 1. ssh 服务…

Webrtc 学习交流

花了几周的时间研究了一下webrtc &#xff0c;并开发了一个小项目&#xff0c;用来点对点私密聊天 交流传输文件等…后续会继续扩展其功能。 体验地址&#xff0c;大狗子的ID,我在线时可以连接测试到我 f3e0d6d0-cfd7-44a4-b333-e82c821cd927 项目特点 除了交换信令与stun 没…

Hadoop分布式配置小白篇(附加各阶段问题解决方式)

看的黑马的课&#xff0c;记录一下配置步骤 目录 1.VMware安装&#xff1a; 方法1&#xff1a; 方法2&#xff1a; 2.创建虚拟机 1.ISO镜像文件获取&#xff08;CentOS&#xff09;&#xff1a; 2.创建&#xff08;简略步骤&#xff09; 3.克隆虚拟机&#xff08;克隆伪…

Flutter在Android Studio上创建项目与构建模式

一、安装插件 1、前提条件&#xff0c;安装配置好Android Studio环境 2、安装Flutter和Dart插件 Linux或者Windows平台&#xff1a; 1&#xff09;、打开File > Settings。 2&#xff09;、在左侧列表中&#xff0c;选择"Plugins"右侧上方面板选中 "Market…

向华为学习:基于BLM模型的战略规划研讨会实操的详细说明,含研讨表单(二)

上一篇文章&#xff0c;华研荟结合自己的经验和实践&#xff0c;详细介绍了基于BLM模型的战略规划研讨会的设计和组织流程&#xff0c;提高效率的做法。有朋友和我私信沟通说&#xff0c;其实这个流程不单单适合于BLM模型的战略规划研讨会&#xff0c;实际上&#xff0c;使用其…

【C++11特性篇】C++11中新增的initializer_list——初始化的小利器(2)

前言 大家好吖&#xff0c;欢迎来到 YY 滴C11系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴C专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; 目录 一.探究std::initializer_list是什么…

【MyBatis-Plus】MyBatis进阶使用

目录 一、MyBatis-Plus简介 1.1 介绍 1.2 优点 1.3 结构 二、MyBatis-Plus基本使用 2.1 配置 2.2 代码生成 2.3 CRUD接口测试 三、MyBatis-Plus策略详解 3.1 主键生成策略 3.2 雪花ID生成器 3.3 字段自动填充策略 3.4 逻辑删除 四、MyBatis-Plus插件使用 4.1 乐…

【笔试强化】Day 4

文章目录 一、单选1.2.3.4.5.6.7. 二、不定项选择1.2.3. 三、编程1. 计算糖果题解&#xff1a;代码&#xff1a; 2. 进制转换题解&#xff1a;代码&#xff1a; 一、单选 1. 正确答案&#xff1a;D队列先进先出 A&#xff1a;栈有关 B&#xff1a;错 C&#xff1a;错 2. 正确…

Linux centos7安装redis 6.2.14 gz并且使用systemctl为开机自启动 / 彻底删除 redis

1.下载 && 减压 wget http://download.redis.io/releases/redis-6.2.14.tar.gz tar -zvxf redis-6.2.14.tar.gz 2.编译&#xff08;分开运行&#xff09; cd redis-6.2.14 make cd src make install 安装目录展示 3.redis.conf 配置更改 daemonize yes supervised s…

轻量封装WebGPU渲染系统示例<48>- 多种光源的多种组合(源码)

实现方式: 1. 全局的灯光和阴影。 2. 球体和矩形平面使用了相同的材质对象。 3. 通过材质自动关联和组装对应的渲染材质功能节点。 当前示例源码github地址: https://github.com/vilyLei/voxwebgpu/blob/feature/material/src/voxgpu/sample/MultiLightsShading2.ts 当前…

python 连接SQL server 请用pymssql连接,千万别用pyodbc

pymssql官方介绍文档 python 使用 pymssql连接 SQL server 代码示例&#xff1a; 安装pymssql包&#xff1a; pip install pymssql代码&#xff1a; import pymssqldef conn_sqlserver_demo():# 连接字符串示例&#xff08;根据您的配置进行修改&#xff09;conn Nonetry:co…

【C++】 C++11 新特性探索:decltype 和 auto

▒ 目录 ▒ &#x1f6eb; 问题描述环境 1️⃣ decltype推导变量类型推导函数返回类型 2️⃣ auto自动推导变量类型迭代器和范围循环 3️⃣ decltype 和 auto 同时使用&#x1f6ec; 结论&#x1f4d6; 参考资料 &#x1f6eb; 问题 描述 C11 引入了一些强大的新特性&#xff…

探索 HBase GUI 工具,助您轻松驾驭大数据世界!

你是否曾为 HBase 数据管理而苦恼&#xff1f;别担心&#xff0c;这一款超级好用的 HBase GUI &#xff08;HBase Assistant&#xff09;工具&#xff0c;让您在大数据世界中游刃有余。不再需要繁琐的命令行操作&#xff0c;也不再为复杂的配置感到头疼。 主要功能 直观和设计…

AttributeError: module ‘edge_tts‘ has no attribute ‘Communicate‘解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

插入排序:直接插入排序 希尔排序

插入排序&#xff1a; 假设红竖线前的元素全部排好序&#xff0c;红线后面的数即为要插入的数据&#xff0c;红线依次往后移&#xff0c;假设end为排好序的最后一个数字&#xff0c;end1即为要插入的数字&#xff0c;一次插入时&#xff0c;end与要插入的数字依次比较&#xf…

自定义时间选择器

自定义时间选择器 文章目录 自定义时间选择器第一章 效果演示第01节 效果图第02节 主要文件 第二章 案例代码第01节 核心文件 WheelPicker第02节 实体类 WheelBean第03节 接口类 IWheelPicker第04节 原子时间类 DateTimePickerView第05节 原子时间类 PickerYear第06节 原子时间…

比特币价格创新高:加密货币的崛起与未来

一、引言 近年来&#xff0c;比特币的价格一路上涨&#xff0c;引起了全球投资者和市场的广泛关注。作为最早一批区块链技术应用案例之一&#xff0c;比特币的成功带动了整个加密货币市场的兴起。本文将探讨比特币价格创新高的原因、加密货币的崛起以及未来发展趋势。 二、比特…