当前位置: 首页 > article >正文

CentOS 7.9源码编译glibc 2.28:从“cannot find -lnss_test2”报错到成功部署的实战复盘

1. 问题背景与复现最近在CentOS 7.9系统上源码编译glibc 2.28时遇到了一个让人头疼的报错/usr/bin/ld: cannot find -lnss_test2。这个错误发生在编译的最后阶段直接导致安装失败。作为一个长期和Linux系统打交道的老手我决定把这个问题的排查和解决过程完整记录下来希望能帮到遇到同样困境的朋友。先说说glibc的重要性。作为GNU C库它是Linux系统中最基础的核心组件之一几乎所有程序都依赖它。升级glibc需要格外小心因为一旦出错轻则个别程序无法运行重则整个系统崩溃。我这次选择源码编译安装glibc 2.28主要是为了满足某些新软件对更高版本glibc的需求。具体报错信息是这样的/usr/bin/ld: cannot find -lnss_test2 collect2: error: ld returned 1 exit status Execution of gcc -B/usr/bin/ failed!这个错误出现在执行make install的时候提示找不到名为nss_test2的库文件。有趣的是这个库并不是系统必需的而是glibc测试套件的一部分。但就是这个测试库却让整个安装过程卡住了。2. 深入分析错误原因为了搞清楚这个问题的根源我花了些时间查阅资料。首先确认这不是个例很多人在升级glibc时都遇到了相同的错误。通过搜索我在glibc的官方bug追踪系统中找到了相关报告编号为11157。问题的本质在于glibc的安装脚本test-installation.pl存在缺陷。这个脚本在安装过程中会检查系统环境其中包含一段对NSSName Service Switch测试库的检查逻辑。原始脚本只排除了nss_test1但没有考虑到nss_test2的情况导致脚本误认为缺少必要库而终止安装。这里需要解释下NSS测试库的作用。nss_test1和nss_test2都是glibc自带的测试用库用于验证NSS模块的功能。它们不是运行时必需的但安装脚本却把它们当成了必须存在的库来检查这显然是个bug。3. 解决方案与实施步骤找到了问题根源解决方法就清晰了。我们需要修改test-installation.pl脚本让它忽略对nss_test2的检查。具体步骤如下首先定位到glibc源码目录下的脚本文件vim glibc-2.28/scripts/test-installation.pl找到第128行左右的代码原始内容是这样的 $name ne nss_test1 $name ne libgcc_s) {我们需要把它修改为 $name ne nss_test1 $name ne nss_test2 $name ne nss_nis $name ne nss_nisplus $name ne libgcc_s) {这个修改不仅添加了对nss_test2的忽略还顺便加上了nss_nis和nss_nisplus因为它们在部分系统上也可能不存在。修改完成后保存文件。然后回到build目录重新执行编译和安装make -j4 make install这次安装应该就能顺利完成了。为了验证安装是否成功可以检查glibc的版本ldd --version如果显示的是2.28版本说明升级成功。4. 完整编译安装流程为了确保完整性我把在CentOS 7.9上编译安装glibc 2.28的完整流程整理如下首先安装必要的开发工具和依赖yum groupinstall Development Tools -y yum install wget bison -y下载glibc 2.28源码包wget https://ftp.gnu.org/gnu/glibc/glibc-2.28.tar.gz解压并进入源码目录tar xvf glibc-2.28.tar.gz cd glibc-2.28创建build目录并配置编译选项mkdir build cd build ../configure --prefix/usr --disable-profile --enable-add-ons --with-headers/usr/include --with-binutils/usr/bin执行编译根据CPU核心数调整-j参数make -j4在安装前记得先备份重要文件cp /usr/bin/ld /usr/bin/ld.bak cp /usr/bin/gcc /usr/bin/gcc.bak应用我们的修复方案修改test-installation.pl脚本后执行安装make install最后验证安装ldd --version5. 注意事项与经验分享在升级glibc这种核心系统组件时有几个重要注意事项首先一定要在测试环境先验证。我最初在CentOS 7.5上尝试时就因为操作不当导致系统崩溃所有命令都无法执行最后只能重装系统。这也是为什么我后来改用CentOS 7.9重新尝试。其次做好完整备份。不仅是系统备份还要备份关键的二进制文件如/usr/bin/ld和/usr/bin/gcc。万一出现问题可以快速恢复。关于依赖库我发现有些教程会建议先安装isl、gmp、mpfr等库。实际上对于glibc编译这些并不是必须的。但如果确实需要注意正确的安装方式。比如isl库的安装正确的配置命令应该是./configure --prefix/usr/local/isl --with-gmp-prefix/usr/local/gmp最后提醒一点升级glibc后不要立即重启系统。先确认所有关键服务都能正常运行特别是那些静态链接glibc的服务。我曾经遇到过升级后某些服务因为glibc版本不兼容而无法启动的情况。

相关文章:

CentOS 7.9源码编译glibc 2.28:从“cannot find -lnss_test2”报错到成功部署的实战复盘

1. 问题背景与复现 最近在CentOS 7.9系统上源码编译glibc 2.28时,遇到了一个让人头疼的报错:/usr/bin/ld: cannot find -lnss_test2。这个错误发生在编译的最后阶段,直接导致安装失败。作为一个长期和Linux系统打交道的老手,我决定…...

零基础转行大模型选哪个岗位方向最易上手?常见问题全解析

零基础转行大模型选哪个岗位方向最易上手?常见问题全解析 标签:#人工智能、#深度学习、#自然语言处理、#神经网络、#机器学习、#计算机视觉、#ai ### 先打破一个误区:大模型≠只有算法岗,普通人也能进### 大模型岗位:哪…...

AIAgent响应延迟超800ms?SITS2026案例实测:4步将LCEL流水线性能提升6.8倍(附压测对比数据)

第一章:SITS2026案例:AIAgent个人助理开发 2026奇点智能技术大会(https://ml-summit.org) SITS2026(Smart Intelligence Technology Showcase 2026)是面向下一代AI原生应用的标杆性实践平台,其中“AIAgent个人助理”…...

非计算机专业转AI Agent:补哪些基础最有效

【本段核心】现在很多大学生都有转AI的想法,但每天做的却是收藏一堆教程、刷一堆概念、看一堆“LLM 从入门到精通”,然后继续焦虑、继续拖沓、继续投简历没回音。我就是双非野鸡二本经济学转Agent的,成效把 Agent 这条路跑通之后,…...

FirPE 维护系统 v2.1.0

FirPE 是一款系统预安装环境(Windows PE),它具有简约、易操作等特点,使用起来十分人性化。以U盘作为使用载体,空间更为充分,携带更为方便。同时整合各种装机必备工具,有效提高系统安装效率。Fir…...

FreeRTOS队列实战:uxQueueMessagesWaiting在UART中断中的那些坑

FreeRTOS队列深度解析:UART中断中的uxQueueMessagesWaiting陷阱与实战对策 在嵌入式开发中,UART通信与FreeRTOS队列的结合使用堪称经典组合,但正是这种看似简单的组合,却暗藏诸多玄机。我曾在一个工业传感器采集项目中&#xff0c…...

3步解锁B站专业直播:告别直播姬限制的终极方案

3步解锁B站专业直播:告别直播姬限制的终极方案 【免费下载链接】bilibili_live_stream_code 用于在准备直播时获取第三方推流码,以便可以绕开哔哩哔哩直播姬,直接在如OBS等软件中进行直播,软件同时提供定义直播分区和标题功能 项…...

Nebula Console深度解析:高效管理图数据库的核心技巧与实战指南

Nebula Console深度解析:高效管理图数据库的核心技巧与实战指南 【免费下载链接】nebula-console Command line interface for the Nebula Graph service 项目地址: https://gitcode.com/gh_mirrors/ne/nebula-console Nebula Console作为NebulaGraph图数据库…...

基于VScode的安装——MinGW的介绍和安装

1、MinGW介绍 MinGW开源免费,是Windows上的GNU编译工具链,核心是把GCC编译器移植到Windows。主要作用是在Windows上用GCC编译C/C等编程语言,直接生成原生Windows .exe可执行文件,只依赖Windows自带的MSVCRT系统库,不依…...

3步实现Chrome浏览器与KeePass密码库无缝同步

3步实现Chrome浏览器与KeePass密码库无缝同步 【免费下载链接】ChromeKeePass Chrome extensions for automatically filling credentials from KeePass/KeeWeb 项目地址: https://gitcode.com/gh_mirrors/ch/ChromeKeePass 你是否厌倦了每次登录网站都要手动输入密码&a…...

B站资源下载终极指南:跨平台BiliTools使用全攻略

B站资源下载终极指南:跨平台BiliTools使用全攻略 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/BiliTools 还在为…...

KP09 Encoder使用教程

注意:请不要同时将两个typec口接入数据线。 2026.3.22更新 汉化版VIAL改键软件,链接:VIAL汉化版——VIAL-JL – yoonas blog 2026.3.23更新 组合键设置 默认功能 1、默认键位 键盘有九个按键,两个旋钮,旋钮可以按下。上…...

CentOS 7 下DNF安装与常见报错解决方案

1. 为什么要在CentOS 7上安装DNF? 很多刚接触CentOS 7的开发者可能会疑惑:系统自带的yum包管理器用得好好的,为什么还要折腾DNF?这个问题我也曾经纠结过。经过实际使用对比,我发现DNF确实有不少优势。 首先&#xff0c…...

从 219 秒到 1.3 秒!CausVid:首个媲美双向扩散的流式视频生成模型深度解析

前言 你是否有过这样的经历:输入一段文本生成视频,盯着屏幕等了 3 分多钟才看到结果?这就是传统双向视频扩散模型的致命痛点 —— 生成 128 帧视频需要 219 秒,且必须等全部内容生成完毕才能观看,更别提中途修改提示词…...

Jvppeteer终极指南:Java开发者如何快速掌握浏览器自动化

Jvppeteer终极指南:Java开发者如何快速掌握浏览器自动化 【免费下载链接】jvppeteer Java API For Chrome and Firefox 项目地址: https://gitcode.com/gh_mirrors/jv/jvppeteer 你是否曾为Java项目中的网页自动化测试、数据抓取或性能分析而烦恼&#xff1f…...

AD9833 vs 传统晶振:在超声波发生器设计中,我们该如何选择?

AD9833与晶振的终极对决:超声波发生器设计中的芯片选型策略 当你在设计一款便携式超声波清洗仪或工业测厚设备时,信号源的选择往往决定了整个项目的成败。面对市场上琳琅满目的解决方案,工程师们常常陷入两难:是选择传统晶振的稳定…...

掌握Jint:避免常见陷阱的10个专业建议

掌握Jint:避免常见陷阱的10个专业建议 【免费下载链接】jint Javascript Interpreter for .NET 项目地址: https://gitcode.com/gh_mirrors/ji/jint Jint是一款功能强大的.NET平台JavaScript解释器,它允许开发者在.NET应用中无缝执行JavaScript代…...

从Focal Loss到ASL:深入聊聊多标签分类损失函数的‘进化史’与调参心得

从Focal Loss到ASL:多标签分类损失函数的演进与实战调优指南 在医学影像分析中,我们常常遇到这样的场景:一张X光片可能同时存在多种病灶特征,但阳性样本(如肿瘤标记)的出现频率往往不足1%。传统二元交叉熵&…...

【情感计算模块性能黄金标准】:IEEE P2892草案未公开的4项硬性指标(含微表情响应延迟≤83ms实测数据)

第一章:情感计算模块在AIAgent架构中的定位与演进脉络 2026奇点智能技术大会(https://ml-summit.org) 情感计算模块已从早期独立的情感识别插件,演变为AIAgent多模态认知闭环中不可或缺的语义调制中枢。它不再仅服务于“检测微笑是否代表愉悦”&#xf…...

baseAdapter高级功能详解:Header、Footer、LoadMore和EmptyView终极指南

baseAdapter高级功能详解:Header、Footer、LoadMore和EmptyView终极指南 【免费下载链接】baseAdapter Android 万能的Adapter for ListView,RecyclerView,GridView等,支持多种Item类型的情况。 项目地址: https://gitcode.com/gh_mirrors/ba/baseAdap…...

从APB1总线时钟到定时器中断:N32G45x TIM2定时器配置全流程解析(附代码)

从APB1总线时钟到定时器中断:N32G45x TIM2定时器配置全流程解析(附代码) 在嵌入式开发中,定时器是最基础也最核心的外设之一。无论是实现精准延时、周期性任务触发,还是生成PWM波形,都离不开对定时器的深入…...

光学仿真进阶:利用MATLAB优化贝塞尔高斯光束传输性能的3个技巧

光学仿真进阶:利用MATLAB优化贝塞尔高斯光束传输性能的3个技巧 贝塞尔高斯光束在激光加工、光学镊子和生物成像等领域展现出独特优势,但精确仿真其传输特性往往面临计算效率与精度的双重挑战。许多工程师在完成基础仿真后,常陷入"参数微…...

有限元分析硬件配置指南:2024年性价比最高的工作站搭建方案

有限元分析硬件配置指南:2024年性价比最高的工作站搭建方案 在工程仿真领域,有限元分析(FEA)已成为产品研发不可或缺的工具。随着计算模型的复杂度不断提升,如何选择一套既能满足计算需求又符合预算的硬件系统&#xf…...

外发文件失控?巴别鸟把断线的风筝拉回来

一位制造业的IT负责人最近向我们诉苦:他们给供应商外发了3D设计文件,对方擅自二次转发给了竞争对手。他花了整整两周才弄清楚文件流向了哪里,而此时损失已经造成。 这几乎是企业文件管理的"经典困境"——文件一旦离开内网&#xff…...

3 个 SCI 论文 Methods 正反案例,手把手教你避坑

摘要:上一篇我们用「菜谱思维」讲透了科技论文 Methods 部分的核心逻辑,很多同学留言说 “道理都懂,一写就废”。本文用 3 个覆盖生物、环境、材料领域的真实正反案例,从拒稿级反面教材,到录用级优化版本,逐…...

如何快速实现AI到PSD的无损转换?Ai2Psd脚本的终极解决方案

如何快速实现AI到PSD的无损转换?Ai2Psd脚本的终极解决方案 【免费下载链接】ai-to-psd A script for prepare export of vector objects from Adobe Illustrator to Photoshop 项目地址: https://gitcode.com/gh_mirrors/ai/ai-to-psd 在专业设计工作流中&am…...

Agents统一综述:Harness、记忆、Skills和协议

可靠的Agent能力不仅来自模型内部参数权重,更来自将认知负担外部化到结构化基础设施中。 近期,上交大、中山大学、卡梅隆等发表长文对 LLM Agents中的外部化:记忆、Skills、协议与Harness工程进行了统一综述 借用认知工具(Cogniti…...

应届生别装熟练!诚实反而更容易过

文章目录 一、那年我面了个"表演型选手",场面一度十分尴尬二、别装了,面试官都是"人形测谎仪"三、"我不会,但我能快速学会"——这句话值多少钱?四、诚实面试的三大实操技巧,拿笔记一下4…...

字节怎么就成了AI界黄埔军校?

现在国内AI圈但凡有点名气的大模型团队,不管是大厂还是六小龙,核心岗位里几乎都能找到从字节出来的人,而且很多都是骨干、负责人、甚至联创。 这很奇怪呀?字节的AI明明是国内第一梯队! 待遇也给得拉满,百…...

如何理解Transformer模块:从Layer Normalization到Feed Forward网络的完整指南

如何理解Transformer模块:从Layer Normalization到Feed Forward网络的完整指南 【免费下载链接】transformer A TensorFlow Implementation of the Transformer: Attention Is All You Need 项目地址: https://gitcode.com/gh_mirrors/tr/transformer Transf…...