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

麒麟系统离线安装PostgreSQL?手把手教你用dnf和repotrack搞定所有依赖包

麒麟系统离线部署PostgreSQL全攻略从依赖包下载到本地仓库构建在政企级IT基础设施中麒麟操作系统因其安全可控的特性成为关键业务系统的首选平台。当这些系统运行在物理隔离的内网环境时如何解决软件依赖的最后一公里问题成为每位运维工程师必须掌握的生存技能。本文将以PostgreSQL数据库部署为案例深度解析两种主流离线依赖解决方案的技术细节与实战技巧。1. 离线环境准备与依赖分析麒麟系统的安全加固机制在提供防护的同时也带来了软件管理的特殊挑战。Kylin-Server-V10-SP3版本默认搭载的DNF包管理器虽然兼容YUM仓库格式但在离线场景下需要特别注意基础环境的一致性。通过rpm -qa | grep postgresql检查系统预装组件时可能会发现某些基础依赖如readline、zlib等已存在但开发包往往缺失。这正是离线环境最典型的依赖陷阱——看似相同的包名可能缺少-devel后缀的开发文件导致后续编译失败。建议在联网环境提前生成完整依赖树dnf repoquery --requires --resolve postgresql-server | sort -u对于ARM64架构的麒麟系统还需特别注意第三方仓库的架构标识aarch64/arm64OpenSSL等基础库的版本兼容性系统默认Python版本与psycopg2适配问题2. 依赖包获取的双刃剑DNF与repotrack对比2.1 精准下载模式dnf --downloadonly适用于已知部分依赖缺失的场景典型操作流程mkdir -p /opt/pg_deps/partial dnf install --downloadonly --destdir/opt/pg_deps/partial \ postgresql-server \ postgresql-contrib \ postgresql-devel优势只下载指定包及其直接依赖节省存储空间较repotrack减少40%-60%适合小规模增量部署缺陷可能遗漏间接依赖需要人工确认基础环境已有组件2.2 全量下载模式repotrack麒麟系统内置的repotrack工具能递归获取所有关联包确保依赖完整性repotrack -a aarch64 -p /opt/pg_deps/full \ postgresql-server \ libicu \ libxslt关键参数说明-a指定架构x86_64/aarch64-p设置下载目录可追加--disableexcludes忽略特殊排除规则典型问题解决方案 当遇到Error: No matching packages时确认仓库配置dnf repolist all检查包名拼写dnf search all keyword尝试添加EPEL等额外仓库3. 构建高可用本地仓库获得RPM包后需要将其转化为可被DNF识别的仓库格式。以下是经过生产验证的最佳实践3.1 仓库目录结构标准化/opt/local_repo/ ├── postgresql/ │ ├── aarch64/ │ │ ├── packages/ │ │ └── repodata/ │ └── noarch/ └── common_deps/ └── aarch64/3.2 使用createrepo_c增强兼容性相比老旧的createrepocreaterepo_c提供更快的元数据生成dnf install createrepo_c cd /opt/pg_deps/full createrepo_c --database --workers4 .高级技巧--update增量更新时使用--recycle-pkglist重用现有文件列表--xz采用更高压缩比3.3 多仓库优先级配置/etc/yum.repos.d/local.repo示例[local-postgres] namePostgreSQL Local Repo baseurlfile:///opt/local_repo/postgresql/aarch64 enabled1 gpgcheck0 priority1 [local-base] nameBase Dependencies baseurlfile:///opt/local_repo/common_deps/aarch64 enabled1 priority5优先级数值越小优先级越高可有效解决依赖冲突。4. 安装验证与故障排除完成仓库配置后通过dnf --enablerepolocal-postgres install postgresql-server进行安装。建议分阶段验证安装阶段检查使用-v参数显示详细安装过程观察是否有Downloading字样出现表明仍在尝试联网检查/var/log/dnf.log中的错误信息运行时验证sudo -u postgres psql -c SELECT version() sudo systemctl start postgresql journalctl -xe --unit postgresql常见故障处理故障现象可能原因解决方案缺少libicu未下载语言包追加libicu到repotrack列表服务启动失败SELinux限制执行restorecon -Rv /var/lib/pgsql连接被拒绝未初始化运行postgresql-setup --initdb对于需要编译扩展的场景建议预先下载这些开发工具repotrack -a aarch64 -p /opt/build_deps \ gcc \ make \ cmake \ postgresql-devel5. 进阶离线环境下的版本升级离线环境的版本迭代需要特别谨慎。推荐采用以下流程在新环境中测试仓库迁移使用dnf history list查看当前事务通过dnf downgrade回滚问题更新保留旧版本仓库作为应急回退创建版本快照的实用命令rpm -qa --qf %{NAME}-%{VERSION}-%{RELEASE}.%{ARCH}\n | sort pg_packages.list在实际的政务云项目中我们曾通过这种离线部署方案在完全隔离的环境中成功部署了PostgreSQL 14集群并实现了跨安全域的同步更新。关键点在于建立完善的依赖包审核流程和版本控制机制。

相关文章:

麒麟系统离线安装PostgreSQL?手把手教你用dnf和repotrack搞定所有依赖包

麒麟系统离线部署PostgreSQL全攻略:从依赖包下载到本地仓库构建 在政企级IT基础设施中,麒麟操作系统因其安全可控的特性成为关键业务系统的首选平台。当这些系统运行在物理隔离的内网环境时,如何解决软件依赖的"最后一公里"问题&am…...

指纹采集器模块选型指南|如何选择合适的指纹采集模块

在做指纹门禁、指纹考勤、指纹保险箱或嵌入式终端时, 指纹采集器模块几乎是整个系统的核心。 模块选对了,项目推进顺畅;选错了,后期调试、售后问题不断。 本文不讲复杂参数,只从实际应用出发, 用最通俗的方…...

OpenWrt补丁踩坑实录:从‘尾随空格’警告到make update失败的完整排错指南

OpenWrt补丁踩坑实录:从‘尾随空格’警告到make update失败的完整排错指南 当你第一次尝试为OpenWrt制作补丁时,可能会觉得这就像在玩一个充满陷阱的迷宫游戏。每次你以为按照教程走就能顺利通关,却总会在某个转角遇到意想不到的错误提示。本…...

避坑指南:PyCharm 2023.3 + Anaconda 虚拟环境配置,绕开‘解释器路径选择界面消失’的陷阱

PyCharm 2023.3与Anaconda虚拟环境深度配置指南:从原理到实战避坑 在数据科学和机器学习项目的开发过程中,PyCharm与Anaconda的组合堪称黄金搭档。然而,当PyCharm 2023.3遇到Anaconda虚拟环境配置时,不少开发者会陷入"解释器…...

小米手机解锁BL保姆级教程:无需社区5级,用PHP脚本绕过HyperOS限制(附常见错误码解决)

小米手机解锁BL实战指南:突破HyperOS限制的完整方案 手里的小米13升级到HyperOS后,解锁Bootloader突然变得遥不可及?社区等级5和答题门槛让不少技术爱好者望而却步。本文将带你深入探索一种巧妙的技术方案,无需满足小米社区的苛刻…...

Git提交者信息填错了?别慌,手把手教你用config命令修正(全局/本地/取消设置全攻略)

Git提交者信息填错了?别慌,手把手教你用config命令修正(全局/本地/取消设置全攻略) 刚提交完代码到Git仓库,突然发现用户名和邮箱填错了?别担心,这种情况几乎每个开发者都遇到过。提交者信息错误…...

RV1106开发板WiFi配置全攻略:从AP模式到STA模式,手把手教你搞定网络连接

RV1106开发板WiFi配置全攻略:从AP模式到STA模式,手把手教你搞定网络连接 刚拿到RV1106开发板时,最让人头疼的莫过于WiFi配置了。这块嵌入式开发板在网络连接上有着独特的配置逻辑,尤其是AP(接入点)和STA&am…...

别再只用BackgroundImage了!C# WinForm窗体背景图5种方法全解析(含PictureBox与资源文件实战)

别再只用BackgroundImage了!C# WinForm窗体背景图5种方法全解析 当我们需要为WinForm窗体添加背景图时,很多开发者会条件反射地使用BackgroundImage属性。这种习惯性选择虽然简单,但在实际项目中可能会遇到性能瓶颈、内存泄漏或适配问题。本文…...

国产芯赋能低功耗人体感应小夜灯方案(YL4056H 充电管理)

一、方案概述人体感应小夜灯作为智能家居入门级产品,核心需求是低功耗、长续航、充电安全、光控 人体感应双触发。本方案基于远乐 YL4056H 高耐压线性锂电充电芯片,搭配 PIR 红外感应模块 光敏电阻,实现 “白天休眠、夜间人来灯亮、人走延时…...

W5500 TCP客户端开发避坑指南:从寄存器配置到稳定通信的5个关键步骤

W5500 TCP客户端开发避坑指南:从寄存器配置到稳定通信的5个关键步骤 在嵌入式网络通信领域,W5500作为一款硬件集成TCP/IP协议栈的以太网控制器,因其易用性和稳定性备受开发者青睐。然而,当项目从实验室demo转向实际部署时&#xf…...

别再死记硬背GitFlow命令了!用SourceTree图形化工具5分钟搞定团队协作流程

告别GitFlow命令行恐惧:用SourceTree可视化工具高效管理团队协作 在中小型技术团队中,版本控制是日常开发不可或缺的环节,但传统的GitFlow工作流常常让非命令行爱好者望而生畏。当团队成员水平参差不齐时,频繁的git merge --no-ff…...

专业影像场景优选:三大维度拆解分析高速稳定CFexpress存储卡如何保障拍摄顺利

文章概览:从工程视角看CFexpress存储卡选型在专业影像制作中,存储卡不仅仅是数据载体,更是整个工作流中的关键节点。针对高强度8K视频录制、RAW格式连拍、不可重拍场景下数据安全等核心诉求,本文对市场上主流CFexpress存储卡进行工…...

福田区全栈式鸿蒙AI数智机关入选全市首批OR示范应用项目,深开鸿筑牢政务安全底座

5月13日,在第五次深圳市OR大会暨软信投促大会上,福田区机关事务管理局申报的全栈式鸿蒙AI数智机关,作为全市首批OR示范应用项目亮相,让区委大院成为备受瞩目的“实景展厅”,吸引了24家企业组团实地调研。作为目前在复合…...

FPGA资源吃紧?看Artix7-35T如何“精打细算”实现MIPI视频解码与HDMI输出

Artix7-35T极限优化:在资源受限FPGA上实现MIPI-HDMI全流程处理 当医疗内窥镜或工业检测设备需要嵌入式图像处理时,工程师们常常面临一个残酷的现实:既要实现复杂的MIPI视频处理流水线,又不得不使用Artix7-35T这类入门级FPGA。这颗…...

别再傻傻分不清了!用一张图看懂SRE、DevOps工程师和传统运维到底差在哪

从技能图谱到职业选择:SRE、DevOps与传统运维的实战边界 在数字化转型浪潮中,企业技术岗位的职责边界正经历着前所未有的重构。当招聘网站上同时出现"SRE工程师"、"DevOps专家"和"云运维主管"时,许多从业者会陷…...

现货TJA1101AHN/0Z是NXP推出的一款高性能、低功耗的汽车以太网PHY芯片,作为TJA1101A的改进版本,专为车载电子系统设计,支持100BASE-T1标准,具备出色的可靠性与集成度

‌TJA1101AHN/0Z‌ 是NXP(恩智浦)推出的一款高性能、低功耗的汽车以太网PHY芯片,作为TJA1101A的改进版本,专为车载电子系统设计,支持100BASE-T1标准,具备出色的可靠性与集成度。核心性能与优势:…...

LAV Filters终极指南:深度解析开源DirectShow解码器的架构原理与实战配置

LAV Filters终极指南:深度解析开源DirectShow解码器的架构原理与实战配置 【免费下载链接】LAVFilters LAV Filters - Open-Source DirectShow Media Splitter and Decoders 项目地址: https://gitcode.com/gh_mirrors/la/LAVFilters LAV Filters是一套基于F…...

C# 零基础到精通教程 - 第五章:数组——批量管理同一类型的数据

5.1 为什么需要数组?5.1.1 没有数组的困境csharp// 如果要存储5个学生的成绩,没有数组的话: int score1 85; int score2 92; int score3 78; int score4 90; int score5 88;// 如果要计算平均分: double average (score1 s…...

深入解析RoboMaster电机数据包:从CAN原始字节到速度、角度、电流的转换全流程

深入解析RoboMaster电机数据包:从CAN原始字节到速度、角度、电流的转换全流程 在机器人竞赛和工业控制领域,CAN总线通信因其高可靠性和实时性成为电机控制的黄金标准。大疆RoboMaster系列电机通过CAN协议传递的8字节数据包,就像一串精心设计的…...

在MMDetection 3.x中手把手复现EfficientDet的BiFPN模块(附代码逐行解读)

在MMDetection 3.x中手把手复现EfficientDet的BiFPN模块(附代码逐行解读) 当目标检测任务遇到多尺度物体时,传统特征金字塔网络(FPN)往往力不从心。EfficientDet提出的BiFPN(加权双向特征金字塔网络&#x…...

告别手动配置!用Matlab+LUA脚本自动化DCA1000雷达数据采集(附1843配置实例)

雷达数据采集自动化:Matlab与LUA脚本的高效协作方案 在毫米波雷达研发领域,数据采集是每个工程师日常工作中不可或缺的环节。传统的手动配置方式不仅耗时耗力,还容易因人为操作失误导致数据质量不稳定。本文将介绍如何通过Matlab与LUA脚本的协…...

OpenAI Codex 安装部署指南:从零到跑通,2026最新版

⏱️ 阅读时间:8分钟 | 📌 难度:入门级 | 🔧 适用系统:macOS / Linux / Windows(WSL2) 前言 距离上次写 Codex 测评已经有一段时间了,这期间 Codex 又经历了好几轮大更新:Computer Use 能力、内…...

手语数字人技术详解:3D 动画生成、动作自然度优化与实时渲染工程实践

一、前言:手语数字人是 AI 手语翻译的 “最后一公里”在国家信息无障碍政策推动下,AI 手语翻译已从技术实验走向大规模落地。但手语不是文字替换,而是身体动作、手部姿态、面部表情、口型同步的综合表达。传统手语生成普遍存在三大问题&#…...

手把手教你用C#搞定海康机器人扫码枪的TCP通信(附完整Socket代码)

工业级条码采集实战:C#与海康扫码枪的TCP通信深度解析 在自动化仓储和智能制造场景中,海康威视工业扫码枪凭借其卓越的解码性能和稳定的通信机制,已成为产线数据采集的首选设备之一。不同于消费级扫码器的即插即用特性,工业级设备…...

C# 零基础到精通教程 - 第六章:方法——让代码“模块化“

6.1 为什么需要方法?6.1.1 没有方法的问题csharp// 没有方法:代码重复、臃肿、难以维护 static void Main() {// 第一次计算两个数的和int a1 10, b1 20;int sum1 a1 b1;Console.WriteLine($"{a1} {b1} {sum1}");// 第二次计算两个数的和…...

单词拆分----dp

思路:刚开始看的时候没有思路,但我看给的样例,可以多次遍历wordDict看。。。好像不太对准备看看题解。首先需要知道这道题的dp的公式代表这什么,dp[i]表示 字符串s从起始位置到位置i,能否被被拆分成字典中的单词&#…...

Jetson Nano避坑指南:从CUDA到YOLOv5,我踩过的那些坑和最终解决方案

Jetson Nano深度排雷手册:CUDA到YOLOv5实战问题全解析 当这块信用卡大小的开发板第一次出现在我的工作台上时,我完全没预料到接下来两周会经历怎样的"技术炼狱"。从CUDA环境变量配置的幽灵报错,到PyTorch的非法指令崩溃&#xff0c…...

Datasheet学习4(Audio)(TODO)

(TODO)...

SaySo 语音识别相关技术解析,从语音输入到可用文本

摘要语音识别正在从一个独立功能,变成越来越多桌面应用里的基础交互能力。对于 SaySo 这类 PC 端语音工具来说,语音识别不仅仅是把声音转成文字,更关键的是如何在桌面工作流中做到识别准确、响应及时、体验稳定。本文将围绕 SaySo 的语音识别…...

我的Type-C串口板又烧了?一个CH340N电路设计中的隐藏坑点与补救方案

我的Type-C串口板又烧了?CH340N电路设计中的隐藏坑点与补救方案 最近在调试一块自制的Type-C转串口板时,连续烧毁了三片CH340N芯片。每次都是刚插上Type-C线缆时工作正常,但一旦给目标板供电,CH340N就会莫名其妙地停止响应&#x…...