手把手教你用阿里云镜像制作glibc.i686离线安装包(CentOS7专属)

news2026/3/14 4:30:51
手把手教你用阿里云镜像制作glibc.i686离线安装包CentOS7专属最近在维护一个老旧的CentOS 7.4生产环境时遇到了一个典型问题一台无法连接外网的服务器需要安装glibc.i686这个32位库以支持某个遗留的32位商业软件。系统自带的ISO镜像里没有这个包而服务器又处于严格的隔离网络。这让我不得不重新思考如何在一个有网的“跳板机”上高效、完整地准备好所有依赖然后打包带到离线环境。经过一番折腾我梳理出了一套基于阿里云镜像站的完整流程不仅解决了眼前的问题还形成了一套可复用的离线包制作方法论。如果你也在为老旧CentOS系统的离线软件部署头疼特别是涉及到像glibc这样核心且依赖复杂的库这篇文章或许能帮你省下不少时间。整个流程的核心思路很清晰在一台能联网的、系统版本与目标环境一致的CentOS 7机器上配置好阿里云的yum源利用yum的--downloadonly参数下载目标包及其所有依赖最后打包带走。听起来简单但实际操作中你会遇到源配置的坑、依赖解析的陷阱以及版本匹配的微妙之处。尤其是CentOS 7.4这个相对早期的版本与后续更新的glibc-2.17子版本之间需要特别注意兼容性。接下来我将分步拆解从环境准备、源配置、下载技巧到打包验证带你走通整个流程。1. 环境准备与版本确认在开始任何操作之前准备工作至关重要。这不仅仅是安装一个软件包而是为另一个隔离环境构建完整的软件交付物。第一步是确保你的“构建机”能联网的机器与目标“离线机”的系统环境尽可能一致。最理想的情况是你有一台纯净安装的CentOS 7.4虚拟机专门用于此目的。如果条件有限至少需要确保主要版本和架构一致。打开终端首先确认系统版本cat /etc/redhat-release对于CentOS 7.4你应该会看到类似CentOS Linux release 7.4.1708 (Core)的输出。接下来确认当前系统已安装的glibc版本这决定了我们后续需要下载的包版本以避免引入不兼容的更新。rpm -q glibc getconf GNU_LIBC_VERSION第一个命令会列出已安装的glibc的x86_64和可能的i686包版本。第二个命令会输出链接库的版本例如glibc 2.17。我们的目标是安装glibc.i686它必须与现有glibc.x86_64的主版本2.17严格一致但子版本如326.el7_9.3最好也匹配或更新以避免依赖冲突。注意在混合版本环境中直接安装一个比现有x86_64版本更新的i686包有时会导致问题。稳妥的做法是让“构建机”的glibc版本与“离线机”完全一致或使用“离线机”当前已安装版本对应的i686包。为了后续操作方便我们创建一个专门的工作目录mkdir -p /opt/offline_packages/glibc_i686 cd /opt/offline_packages/glibc_i686这个目录将存放所有下载的RPM包和最终的打包文件。2. 配置阿里云Yum源避坑指南很多教程会直接让你修改/etc/yum.repos.d/CentOS-Base.repo但在实际操作中尤其是在一些最小化安装的系统或特定的云镜像上你可能会遇到各种网络或仓库元数据错误。基于阿里云镜像站我们采用一种更彻底、更稳定的配置方法。首先备份现有的仓库配置文件是一个好习惯mkdir -p /etc/yum.repos.d/backup mv /etc/yum.repos.d/*.repo /etc/yum.repos.d/backup/ 2/dev/null接下来直接从阿里云下载针对CentOS 7的官方repo文件。这里我推荐使用curl命令它通常比wget更广泛地存在于最小化系统中。curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo下载完成后不要急着运行yum makecache。我们先来检查一下这个repo文件的内容特别是baseurl和mirrorlist的设置。用cat或vim查看cat /etc/yum.repos.d/CentOS-Base.repo | grep -A2 -B2 baseurl\|mirrorlist你会发现阿里云的repo文件通常已经将mirrorlist注释掉并启用了指向阿里云镜像站的baseurl。这是正确的。但有时特别是在CentOS 7.4这种已经结束标准支持、进入vault阶段的版本默认的baseurl可能指向不存在的updates仓库。我们需要针对7.4.1708进行微调。CentOS的vault仓库归档了历史版本的所有包。对于7.4我们需要确保base和updates仓库指向正确的vault路径。编辑CentOS-Base.repo文件找到[base]和[updates]部分将其baseurl修改如下[base] nameCentOS-$releasever - Base - mirrors.aliyun.com baseurlhttps://mirrors.aliyun.com/centos-vault/7.4.1708/os/$basearch/ gpgcheck1 gpgkeyhttps://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7 [updates] nameCentOS-$releasever - Updates - mirrors.aliyun.com baseurlhttps://mirrors.aliyun.com/centos-vault/7.4.1708/updates/$basearch/ gpgcheck1 gpgkeyhttps://mirrors.aliyun.com/centos/RPM-GPG-KEY-CentOS-7关键改动是将URL中的$releasever替换为具体的7.4.1708并将路径前缀从/centos/改为/centos-vault/。这样yum就会从阿里云的归档镜像中查找适用于7.4.1708的确切软件包。修改完成后清理旧的yum缓存并建立新缓存yum clean all yum makecache如果一切顺利你会看到缓存成功建立的信息。此时可以运行yum repolist来验证仓库是否已正确启用并列出可用的软件包数量。3. 使用--downloadonly下载包与依赖配置好源之后就可以开始下载glibc.i686了。yum命令的--downloadonly参数是我们的核心工具它允许我们只下载软件包及其所有依赖而不进行安装。基本命令格式如下yum install --downloadonly --downloaddir/opt/offline_packages/glibc_i686 glibc.i686这个命令会解析glibc.i686的依赖树并将所有需要下载的RPM包包括glibc.i686本身及其依赖保存到指定的/opt/offline_packages/glibc_i686目录。但在实际执行时你可能会遇到一些意想不到的情况。例如系统可能已经安装了glibc.x86_64的某个版本而yum在解决依赖时可能会试图更新这个x86_64包以及相关的common包。这会导致下载的包数量远超预期。为了更精确地控制下载内容我们可以使用yumdownloader工具它需要单独安装但提供了更精细的控制。首先安装yum-utils它包含了yumdownloaderyum install -y yum-utils然后使用yumdownloader来下载指定包及其依赖yumdownloader --destdir/opt/offline_packages/glibc_i686 --resolve glibc.i686--resolve参数会自动解决并下载依赖。为了更清晰地了解下载了哪些包我们可以结合repoquery命令先查看依赖关系repoquery --requires --resolve glibc.i686这个命令会列出glibc.i686的所有依赖包名。根据输出我们可以发现除了glibc.i686本身关键的依赖通常包括glibc-common(与glibc主版本匹配)nss-softokn-freebl.i686(一个32位的安全库)nss-softokn-freebl.x86_64(对应的64位库可能被更新)nspr(Netscape便携运行时)nss-util(NSS工具库)理解了这个依赖链我们就能更好地解释下载列表并在后续的离线安装中做到心中有数。下载完成后进入目录查看ls -lh /opt/offline_packages/glibc_i686/你应该能看到一系列.rpm文件。用下面的命令统计一下总大小和文件数量du -sh /opt/offline_packages/glibc_i686/ ls /opt/offline_packages/glibc_i686/*.rpm | wc -l一个完整的glibc.i686离线包集合通常在6到8个RPM文件总大小约20-25MB。4. 依赖分析与完整性校验仅仅下载了文件还不够我们必须确保这个包集合在离线环境下能顺利安装。依赖缺失或版本冲突是离线安装失败的最常见原因。因此在打包之前进行一次本地的模拟安装测试是非常有价值的。我们可以使用rpm命令的-Uvh升级/安装配合--test测试模式来检查依赖是否满足而无需实际安装cd /opt/offline_packages/glibc_i686 rpm -Uvh --test *.rpm如果这个命令能顺利执行完毕没有报出缺失依赖的错误那么恭喜你包集合基本是完整的。但有时测试模式可能不会发现所有问题特别是当系统中已经存在某些包的老版本时。一个更彻底的方法是在一个干净的容器或临时虚拟机中测试安装但这对于快速流程来说可能有些重。另一种实用的方法是使用yum localinstall的--nogpgcheck和--disablerepo选项在构建机上直接安装然后再卸载。不过这可能会污染你的构建机环境。我个人的习惯是在下载目录下创建一个简单的检查脚本利用rpm -qpR来查询每个包的依赖并与下载列表进行比对。创建一个名为check_deps.sh的脚本#!/bin/bash for rpm_file in *.rpm; do echo 检查 $rpm_file 的依赖: rpm -qpR $rpm_file 2/dev/null | while read dep; do # 过滤掉 rpmlib 和 rtld 这类虚拟依赖 if [[ ! $dep ~ ^rpmlib ! $dep ~ ^rtld ]]; then # 检查依赖是否由已下载的某个包提供 if ! rpm -q --whatprovides $dep /dev/null; then # 检查依赖是否在当前的下载目录中能找到对应的包文件通过包名模糊匹配 dep_name$(echo $dep | cut -d -f1) if ! ls | grep -q $dep_name; then echo 可能缺失依赖: $dep fi fi fi done done运行这个脚本(bash check_deps.sh)它会给出潜在的缺失依赖警告。对于glibc.i686最常见的“漏网之鱼”就是nss-softokn-freebl.i686这个32位依赖包它有时不会作为glibc.i686的直接依赖被yumdownloader --resolve捕获但却是运行时必需的。如果你在下载列表中没有看到它需要手动补充下载yumdownloader --destdir/opt/offline_packages/glibc_i686 --resolve nss-softokn-freebl.i6865. 打包、传输与离线安装实战确认所有必需的RPM包都已就位后就可以进行打包了。使用tar命令是最通用、最兼容的方式。cd /opt/offline_packages tar -zcvf glibc_i686_offline_centos7.4.tar.gz glibc_i686/这个命令会创建一个名为glibc_i686_offline_centos7.4.tar.gz的压缩包包含了整个glibc_i686目录及其下的所有RPM文件。你可以使用scp、sftp或者U盘等方式将这个压缩包传输到离线的目标服务器上。在目标服务器上假设你将压缩包放在了/tmp目录解压并安装mkdir -p /opt/install_glibc cd /opt/install_glibc tar -zxvf /tmp/glibc_i686_offline_centos7.4.tar.gz cd glibc_i686现在开始安装。由于是离线环境且我们已经确保了依赖的完整性可以使用rpm命令强制安装忽略GPG签名检查因为包来自可信的阿里云镜像且环境隔离风险可控rpm -Uvh --force --nodeps *.rpm参数解释-Uvh: 升级或安装包并显示详细信息和进度条。--force: 强制安装即使会替换掉已有的文件或包。--nodeps: 不检查依赖关系。仅在确定依赖已全部满足时使用。因为我们之前已经做过完整性校验所以这里可以加上。安装过程会显示一系列进度。安装完成后验证glibc.i686是否已成功安装rpm -qa | grep glibc你应该能看到glibc-2.17-xxx.i686出现在列表中。此外还可以用ldd命令测试一个32位的动态链接程序如果有的话或者直接检查库文件是否存在ls -l /usr/lib/libc.so.6 # 或者检查32位库路径 ls -l /usr/lib/ld-linux.so.2最后别忘了清理临时文件rm -rf /opt/install_glibc # 或者保留安装包以备不时之需6. 常见问题与进阶技巧在实际操作中你可能会遇到一些棘手的情况。这里我总结几个常见问题及其解决方案。问题一下载时遇到“No package glibc.i686 available.”这通常是因为你的yum仓库配置没有包含updates仓库或者仓库中没有对应架构的包。确保你的/etc/yum.repos.d/CentOS-Base.repo中[base]和[updates]部分的baseurl指向了正确的vault路径如步骤2所述并且包含了$basearch变量它能自动扩展为i686或x86_64。你也可以显式地搜索yum search glibc.i686 --showduplicates问题二离线安装时rpm -Uvh报错“conflicts with file from package...”这通常是因为要安装的包中的某个文件与系统已安装的其他包的文件冲突。--force参数可以覆盖文件但需谨慎。更好的方法是先尝试移除冲突的旧包如果允许或者使用rpm的--replacefiles和--replacepkgs选项。在离线环境下最安全的做法是确保你下载的包版本与目标系统上已安装的相关包版本匹配或兼容。问题三如何为多个离线服务器批量制作离线包如果你需要为多台相同环境的服务器准备离线包上述流程可以脚本化。下面是一个简化的脚本框架你可以将其保存为build_offline_pkg.sh#!/bin/bash # 定义包名和输出目录 PACKAGE_NAMEglibc.i686 OUTPUT_DIR/opt/offline_packages/${PACKAGE_NAME//./_} mkdir -p $OUTPUT_DIR # 备份并配置阿里云vault源假设已准备好针对7.4.1708的repo文件 REPO_FILECentOS-Base-7.4.repo if [ -f ./$REPO_FILE ]; then cp ./$REPO_FILE /etc/yum.repos.d/CentOS-Base.repo yum clean all yum makecache else echo 错误未找到repo配置文件 $REPO_FILE exit 1 fi # 下载包及依赖 echo 正在下载 $PACKAGE_NAME 及其依赖... yumdownloader --destdir$OUTPUT_DIR --resolve $PACKAGE_NAME # 检查并补充常见易遗漏依赖 EXTRA_DEPSnss-softokn-freebl.i686 for dep in $EXTRA_DEPS; do if ! ls $OUTPUT_DIR/*.rpm 2/dev/null | grep -q $dep; then echo 补充下载依赖: $dep yumdownloader --destdir$OUTPUT_DIR --resolve $dep fi done # 打包 cd /opt/offline_packages TARBALL${PACKAGE_NAME}_offline_$(date %Y%m%d).tar.gz tar -zcvf $TARBALL $(basename $OUTPUT_DIR) echo 离线包已创建: /opt/offline_packages/$TARBALL echo 文件列表: ls -lh $OUTPUT_DIR/问题四除了glibc.i686其他包怎么做这套方法论具有普适性。对于任何需要通过yum安装的软件包流程都是相通的在联网环境配置与目标机一致的系统版本和仓库。使用yumdownloader --resolve下载目标包。通过rpm -Uvh --test或依赖分析脚本检查完整性。打包传输在离线机安装。关键在于第一步的版本一致性和仓库配置。对于更复杂的软件组如development或包含大量依赖的软件如docker-ce下载的包数量会很多需要确保有足够的磁盘空间并且在离线安装时注意安装顺序通常rpm -Uvh *.rpm可以一次性解决。7. 版本匹配与长期维护建议为CentOS 7.4这样的老旧系统维护离线软件库最大的挑战来自于版本锁定和软件源归档。CentOS 7.4已于2020年8月结束维护其标准仓库已移至vault.centos.org。阿里云镜像站同步了这些vault仓库这为我们提供了便利。当你需要为不同的小版本如7.4、7.9制作离线包时务必在baseurl中精确指定版本号。例如对于7.9应使用baseurlhttps://mirrors.aliyun.com/centos-vault/7.9.2009/os/$basearch/。对于glibc这样的核心库我强烈建议在离线机上安装之前先记录下其精确版本号。你可以通过离线机上的rpm -qa | grep glibc获取然后在构建机上通过yumdownloader指定版本下载yumdownloader --destdir/path/to/dir --resolve glibc-2.17-326.el7_9.3.i686这样可以绝对保证版本一致。为了便于长期管理你可以建立一个简单的目录结构来存放不同系统版本和软件包的离线资源/opt/offline_repo/ ├── centos7.4/ │ ├── glibc.i686/ │ │ └── glibc_i686_offline_20231027.tar.gz │ └── other_packages/ ├── centos7.9/ │ ├── docker-ce/ │ └── python3/ └── repo_files/ ├── CentOS-Base-7.4.repo └── CentOS-Base-7.9.repo将对应版本的repo文件也一并归档这样即使未来需要重新制作或验证也能快速还原构建环境。维护离线库虽然繁琐但对于无法连接互联网的关键生产环境这是一项必要且值得投入的工作。每次成功部署一个离线包都是对系统稳定性和可维护性的一次加固。

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

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

相关文章

SpringBoot-17-MyBatis动态SQL标签之常用标签

文章目录 1 代码1.1 实体User.java1.2 接口UserMapper.java1.3 映射UserMapper.xml1.3.1 标签if1.3.2 标签if和where1.3.3 标签choose和when和otherwise1.4 UserController.java2 常用动态SQL标签2.1 标签set2.1.1 UserMapper.java2.1.2 UserMapper.xml2.1.3 UserController.ja…

wordpress后台更新后 前端没变化的解决方法

使用siteground主机的wordpress网站,会出现更新了网站内容和修改了php模板文件、js文件、css文件、图片文件后,网站没有变化的情况。 不熟悉siteground主机的新手,遇到这个问题,就很抓狂,明明是哪都没操作错误&#x…

网络编程(Modbus进阶)

思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…

UE5 学习系列(二)用户操作界面及介绍

这篇博客是 UE5 学习系列博客的第二篇,在第一篇的基础上展开这篇内容。博客参考的 B 站视频资料和第一篇的链接如下: 【Note】:如果你已经完成安装等操作,可以只执行第一篇博客中 2. 新建一个空白游戏项目 章节操作,重…

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…

XML Group端口详解

在XML数据映射过程中&#xff0c;经常需要对数据进行分组聚合操作。例如&#xff0c;当处理包含多个物料明细的XML文件时&#xff0c;可能需要将相同物料号的明细归为一组&#xff0c;或对相同物料号的数量进行求和计算。传统实现方式通常需要编写脚本代码&#xff0c;增加了开…

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明

LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造&#xff0c;完美适配AGV和无人叉车。同时&#xff0c;集成以太网与语音合成技术&#xff0c;为各类高级系统&#xff08;如MES、调度系统、库位管理、立库等&#xff09;提供高效便捷的语音交互体验。 L…

(LeetCode 每日一题) 3442. 奇偶频次间的最大差值 I (哈希、字符串)

题目&#xff1a;3442. 奇偶频次间的最大差值 I 思路 &#xff1a;哈希&#xff0c;时间复杂度0(n)。 用哈希表来记录每个字符串中字符的分布情况&#xff0c;哈希表这里用数组即可实现。 C版本&#xff1a; class Solution { public:int maxDifference(string s) {int a[26]…

【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型

摘要 拍照搜题系统采用“三层管道&#xff08;多模态 OCR → 语义检索 → 答案渲染&#xff09;、两级检索&#xff08;倒排 BM25 向量 HNSW&#xff09;并以大语言模型兜底”的整体框架&#xff1a; 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后&#xff0c;分别用…

【Axure高保真原型】引导弹窗

今天和大家中分享引导弹窗的原型模板&#xff0c;载入页面后&#xff0c;会显示引导弹窗&#xff0c;适用于引导用户使用页面&#xff0c;点击完成后&#xff0c;会显示下一个引导弹窗&#xff0c;直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…

观成科技:隐蔽隧道工具Ligolo-ng加密流量分析

1.工具介绍 Ligolo-ng是一款由go编写的高效隧道工具&#xff0c;该工具基于TUN接口实现其功能&#xff0c;利用反向TCP/TLS连接建立一条隐蔽的通信信道&#xff0c;支持使用Let’s Encrypt自动生成证书。Ligolo-ng的通信隐蔽性体现在其支持多种连接方式&#xff0c;适应复杂网…

铭豹扩展坞 USB转网口 突然无法识别解决方法

当 USB 转网口扩展坞在一台笔记本上无法识别,但在其他电脑上正常工作时,问题通常出在笔记本自身或其与扩展坞的兼容性上。以下是系统化的定位思路和排查步骤,帮助你快速找到故障原因: 背景: 一个M-pard(铭豹)扩展坞的网卡突然无法识别了,扩展出来的三个USB接口正常。…

未来机器人的大脑:如何用神经网络模拟器实现更智能的决策?

编辑&#xff1a;陈萍萍的公主一点人工一点智能 未来机器人的大脑&#xff1a;如何用神经网络模拟器实现更智能的决策&#xff1f;RWM通过双自回归机制有效解决了复合误差、部分可观测性和随机动力学等关键挑战&#xff0c;在不依赖领域特定归纳偏见的条件下实现了卓越的预测准…

Linux应用开发之网络套接字编程(实例篇)

服务端与客户端单连接 服务端代码 #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <arpa/inet.h> #include <pthread.h> …

华为云AI开发平台ModelArts

华为云ModelArts&#xff1a;重塑AI开发流程的“智能引擎”与“创新加速器”&#xff01; 在人工智能浪潮席卷全球的2025年&#xff0c;企业拥抱AI的意愿空前高涨&#xff0c;但技术门槛高、流程复杂、资源投入巨大的现实&#xff0c;却让许多创新构想止步于实验室。数据科学家…

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…