解决:centos7 中node: /lib64/libm.so.6: version `GLIBC_2.27‘ not found (required by node)

文章讲述了在CentOS7环境中遇到node.js因缺失GLIBC版本而报错的问题,详细描述了升级gcc到devtoolset-8、安装glibc2.28、解决动态库冲突等步骤,以及注意事项和未解决的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1.查询系统中glib成的版本

是没有错误提示中的 GLIBC_2.27

2.安装gcc

4.安装GLIBC_2.28


在上一篇《CentOS7安装nvm与node》后执行node发现系统报错

node: /lib64/libm.so.6: version `GLIBC_2.27' not found (required by node)
node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found (required by node)
node: /lib64/libstdc++.so.6: version `CXXABI_1.3.9' not found (required by node)
node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by node)
node: /lib64/libc.so.6: version `GLIBC_2.28' not found (required by node)
node: /lib64/libc.so.6: version `GLIBC_2.25' not found (required by node)

,百度了一些文章,但中间遇到了两个问题。一个是升级gcc失败,另一个是通过 make 安装glibc2.28导致系统崩溃。。特此梳理下。

如果正在使用云服务器,建议在更新前最好备份下系统。言归正传,我们按步骤来解决这个问题

1.查询系统中glib成的版本
$ strings /lib64/libc.so.6 | grep GLIBC
GLIBC_2.2.5
GLIBC_2.2.6
GLIBC_2.3
GLIBC_2.3.2
GLIBC_2.3.3
GLIBC_2.3.4
GLIBC_2.4
GLIBC_2.5
GLIBC_2.6
GLIBC_2.7
GLIBC_2.8
GLIBC_2.9
GLIBC_2.10
GLIBC_2.11
GLIBC_2.12
GLIBC_2.13
GLIBC_2.14
GLIBC_2.15
GLIBC_2.16
GLIBC_2.17
GLIBC_PRIVATE
是没有错误提示中的 GLIBC_2.27
2.安装gcc

要在 centos 7 上升级gcc (使用devtoolset-8-gcc安装gcc8):

# 直接安装 GCC-8 --注意 高版本不一定能编译glic
$ yum install -y devtoolset-8-gcc devtoolset-8-gcc-c++ devtoolset-8-binutils
# 设置环境变量
$ echo "source /opt/rh/devtoolset-8/enable" >> /etc/profile

$ source /etc/profile

# 安装gcc 
$wget https://mirrors.cloud.tencent.com/gnu/gcc/gcc-8.5.0/gcc-8.5.0.tar.gz
# 腾讯软件源 https://mirrors.cloud.tencent.com/gnu/gcc/gcc-8.5.0/gcc-8.5.0.tar.gz
$tar -zxvf gcc-8.5.0.tar.gz
$cd gcc-8.5.0

# 下载依赖及配置文件
yum -y install bzip2 #已安装可以跳过这一步
# 中标麒麟系统需要以下依赖
# yum -y install gmp mpfr mpc isl bzip2
 
$./contrib/download_prerequisites

$mkdir build && cd build/
$../configure -enable-checking=release -enable-languages=c,c++ -disable-multilib

    # --prefix=/usr/local 配置安装目录
    #–enable-languages表示你要让你的gcc支持那些语言,
    #–disable-multilib不生成编译为其他平台可执行代码的交叉编译器。
    #–disable-checking生成的编译器在编译过程中不做额外检查,
    #也可以使用*–enable-checking=xxx*来增加一些检查
# 编译
$make
    #这一步需要时间非常久 可以使用 make -j 4 让make最多运行四个编译命令同时运行,加快编译速度(建议不要超过CPU核心数量的2倍)
#安装
$make install

#验证gcc版本

$gcc -v
 

验证:gcc -v;或者g++ -v,如果显示的gcc版本仍是以前的版本,就需要重启系统;
或者可以查看gcc的安装位置:which gcc;
然后在查看版本 /usr/local/bin/gcc -v
确定以及配置成功后可以将原先的版本删除

3.升级make

$ wget --no-check-certificate https://ftp.gnu.org/gnu/make/make-4.3.tar.gz
$ tar -xzvf make-4.3.tar.gz 
$ cd make-4.3/

# 安装到指定目录
$ ./configure  --prefix=/usr/local/make
$ make
$ make install

# 创建软链接
$ cd /usr/bin/
$ mv make make.bak # backup
$ ln -sv /usr/local/make/bin/make /usr/bin/make
4.安装GLIBC_2.28
# 下载并解压 glibc-2.28
$ wget --no-check-certificate https://ftp.gnu.org/gnu/glibc/glibc-2.28.tar.gz
$ tar -xzvf glibc-2.28.tar.gz
$ cd glibc-2.28

# 创建临时文件
$ mkdir build && cd build

$ ../configure --prefix=/usr --disable-profile --enable-add-ons --with-headers=/usr/include --with-binutils=/usr/bin
$ make
$ make install

# 再次查询
$ strings /lib64/libc.so.6 | grep GLIBC
...
GLIBC_2.22
GLIBC_2.23
GLIBC_2.24
GLIBC_2.25
GLIBC_2.26
GLIBC_2.27
GLIBC_2.28
GLIBC_PRIVATE
...

在glibc make install 时提示:

 
make[1]: *** [Makefile:111: install] Error 1
make[1]: Leaving directory '/data/src/glibc-2.28'
make: *** [Makefile:12: install] Error 2
 

但又说有两个错误也没有关系,到此GLIBC已经成功更新。

截止目前还有以下问题没有解决。

node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found (required by node)
node: /lib64/libstdc++.so.6: version `CXXABI_1.3.9' not found (required by node)
node: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by node)

出现/usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found的问题,是因为生成的动态库没有替换老版本gcc的动态库导致的。将gcc最新版本的动态库替换系统中老版本的动态库即可解决。

1、运行以下命令检查动态库
$strings /usr/lib64/libstdc++.so.6 | grep GLIBC  #下图区别新旧版本
 
2、查找编译gcc时生成的最新动态库
$find / -name "libstdc++.so*"
 
3、挑选最新的动态库
/home/lcc/gcc-12.2.0/stage1-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.30 #最新动态库
注意是选择 stage1-x86_64-pc-linux-gnu 目录下的
 
 
4、将上面的最新动态库 libstdc++.so.6.0.30 复制到/usr/lib64目录下:
$cp /home/lcc/gcc-12.2.0/stage1-x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.30 /usr/lib64
 
5、到/usr/lib64中删除原来的软链接:libstdc++.so.6 -> libstdc++.so.6.0.19,改成libstdc++.so.6 -> libstdc++.so.6.0.30
 
具体操作:
$mv   libstdc++.so.6  libstdc++.so.6.bak #删除
$ln -s libstdc++.so.6.0.30 libstdc++.so.6  #链接
$strings /usr/lib64/libstdc++.so.6 | grep GLIBC  #重新运行查看动态库

<think>好的,用户的问题是关于在CentOS 7.9上运行ollama时遇到缺少GLIBC_2.27的错误。首先,我需要回忆一下GLIBC在Linux系统中的重要性。GLIBC是系统的核心库,很多应用程序都依赖它,直接升级可能会影响系统稳定性,所以得小心处理。 接下来,用户提到的错误信息是/lib64/libm.so.6找不到GLIBC_2.27。根据引用[1],CentOS 7默认的GLIBC版本可能较低,比如2.17,而新版的Node.js需要2.27。同样,ollama可能也是因为编译时使用了更高版本的GLIBC,导致在低版本系统上运行出错。 用户提供的引用中,有几个解决方案。引用[2]建议不要直接升级GLIBC,而是考虑其他方法。引用[3]和[1]提到了手动编译安装GLIBC 2.28的步骤,但同时也警告了风险。引用[4]提到使用预编译的Node.js版本,可能适用于其他软件。 我需要整理这些信息,给出用户可行的解决方案。首先应该建议用户检查当前系统的GLIBC版本,确认是否确实缺少2.27。然后,考虑安全的方法,比如使用容器或静态编译的版本,避免直接升级GLIBC。如果用户坚持升级,需要详细说明步骤,并强调风险,比如系统崩溃或软件不兼容。 另外,ollama可能有其他安装方式,比如使用Docker容器,这样可以利用容器内的GLIBC版本,而不用修改宿主机。这也是一个比较安全的方法,应该推荐给用户。 还要考虑用户是否有网络访问权限,引用[3]中提到无网络环境下的处理,可能需要手动下载并传输文件到服务器。如果用户的环境无网络,可能需要指导如何获取所需的包。 最后,生成相关问题,帮助用户进一步解决可能遇到的问题,比如如何检查GLIBC版本,其他兼容性问题等。</think>### 解决方案:CentOS 7.9运行ollama缺少GLIBC_2.27解决方法 #### 1. 问题分析 ollama运行时依赖的GLIBC版本要求为2.27,但CentOS 7.9默认安装的GLIBC版本为2.17[^1]。直接升级系统GLIBC可能破坏系统稳定性,建议按以下顺序尝试解决方案: #### 2. 推荐方案:使用容器化部署 **推荐理由**:避免直接修改系统库 ```bash # 安装Docker sudo yum install docker -y sudo systemctl start docker # 运行ollama官方镜像 docker run -d --name ollama -p 11434:11434 ollama/ollama ``` 通过容器运行可隔离GLIBC依赖,无需修改宿主系统[^2]。 #### 3. 替代方案:使用静态编译版本 联系ollama开发者获取静态编译版本(包含所需GLIBC),或自行编译: ```bash # 示例编译环境设置(需联网) git clone https://github.com/ollama/ollama.git cd ollama CGO_ENABLED=0 go build -tags=static -o ollama ``` #### 4. 高风险方案:升级GLIBC(仅限测试环境) **步骤说明**: 1. 验证当前版本: ```bash strings /lib64/libc.so.6 | grep GLIBC_ ``` 2. 下载并编译GLIBC 2.27: ```bash wget http://ftp.gnu.org/gnu/glibc/glibc-2.27.tar.gz tar -xzf glibc-2.27.tar.gz mkdir glibc-2.27/build && cd glibc-2.27/build ../configure --prefix=/opt/glibc-2.27 --disable-werror make -j4 && sudo make install ``` 3. 配置动态链接库路径: ```bash echo '/opt/glibc-2.27/lib' | sudo tee /etc/ld.so.conf.d/glibc-2.27.conf sudo ldconfig ``` **重要警告**: - 此操作可能导致系统命令(如`ls`, `yum`等)崩溃[^3] - 必须保留原始GLIBC备份 - 建议在虚拟机环境测试 #### 5. 兼容性方案:使用Alien库 通过非系统路径加载高版本GLIBC: ```bash # 创建独立环境 mkdir ~/glibc_env && cd ~/glibc_env wget http://ftp.gnu.org/gnu/glibc/glibc-2.27.tar.gz tar -xzf glibc-2.27.tar.gz cd glibc-2.27/build ../configure --prefix=$HOME/glibc_env make && make install # 运行程序时指定库路径 LD_LIBRARY_PATH=$HOME/glibc_env/lib ./ollama ```
评论 10
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值