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

从20.03 SP3到24.03 LTS:我的openEuler大版本升级实战与避坑全记录

从20.03 SP3到24.03 LTS我的openEuler大版本升级实战与避坑全记录去年夏天当我第一次在服务器监控面板上看到openEuler 20.03-LTS-SP3即将停止维护的警告时就知道一场硬仗要来了。作为团队里负责基础设施的老运维我经历过太多次系统升级的惊心动魄——服务不可用、依赖地狱、配置丢失...这次我决定用最谨慎的态度对待从20.03到24.03的跨越式升级。本文将完整还原我历时三周的升级历程重点不是教科书式的命令列表而是那些只有实战才会遇到的坑与应对策略。1. 升级前的战略准备在真正执行dnf distro-sync之前我花了整整五天做准备工作。大版本升级不是简单的软件更新而是操作系统的心脏移植手术任何疏忽都可能导致业务中断。1.1 环境全面体检首先用脚本收集系统全貌信息远比简单的cat /etc/openEuler-latest更全面#!/bin/bash echo 系统基础信息 cat /etc/os-release uname -a rpm -qa | grep kernel | sort df -h echo 关键服务状态 systemctl list-units --typeservice --staterunning journalctl --since 1 week ago -p err这个检查让我发现了三个隐患旧内核残留系统存在4.19.90和5.10.0两个内核版本磁盘空间紧张/boot分区只剩200MB空间自定义内核模块NVIDIA驱动和VirtualBox模块需要重新编译1.2 备份策略的陷阱大多数教程都会告诉你备份配置文件但实际生产环境需要更细致的方案备份类型工具/方法恢复测试要点配置文件tar -zcvf /etc_backup.tgz /etc权限保留验证数据库mysqldump binlog数据一致性检查应用数据LVM快照 rsync文件完整性校验服务状态systemctl list-units --all services.txt依赖关系重建特别提醒不要依赖单一种备份方式。我在测试恢复时发现简单的tar备份会丢失SELinux上下文导致某些服务无法启动。2. 升级过程中的六大实战难题2.1 依赖冲突的拆弹艺术执行dnf distro-sync时遭遇的依赖冲突堪称升级路上的第一只拦路虎。典型报错如下Error: Problem: package A-1.0-1.oe1.x86_64 requires B 2.0, but none of the providers can be installed - package C-3.0-1.oe2403.x86_64 conflicts with B 3.0 provided by B-2.0-1.oe1.x86_64我的解决路线图先用dnf repoquery --deplist分析依赖树对非核心包使用--skip-broken临时跳过关键服务依赖则手动下载rpm包强制安装记录操作日志最终通过dnf swap B C实现依赖替换警告强制安装(--nodeps)是最后手段必须记录每个被跳过的依赖项升级后立即验证相关服务。2.2 密钥风暴的平息从20.03升级到24.03会遇到GPG密钥的世代更替问题。错误提示通常是warning: /var/cache/dnf/packages/openEuler-gpg-keys-1.0-3.7.oe2403.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID fb37bc6f: NOKEY标准解决方案是rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY-openEuler但真实场景更复杂某些镜像站点的密钥文件路径不同企业内网可能需要先部署本地密钥服务器在CI/CD环境中需要预先注入密钥我最终采用的组合拳# 先清除旧密钥 rpm -e gpg-pubkey-$(rpm -qa gpg-pubkey --qf %{NAME}-%{VERSION}-%{RELEASE}\n) # 安装新版本密钥包 curl -O https://repo.openeuler.org/openEuler-24.03-LTS/OS/x86_64/Packages/openEuler-gpg-keys-1.0-3.7.oe2403.x86_64.rpm rpm -ivh openEuler-gpg-keys-*.rpm # 验证密钥指纹 gpg --quiet --with-fingerprint /etc/pki/rpm-gpg/RPM-GPG-KEY-openEuler3. 升级后的关键验证步骤系统重启只是开始真正的考验在服务恢复阶段。我设计了一套验证checklist3.1 基础环境验证# 内核与用户空间一致性检查 uname -r # 应为6.6.x grep PRETTY_NAME /etc/os-release # 确认24.03 ldd --version # glibc版本兼容性 # 关键路径权限检查 restorecon -Rv /etc /usr/lib/systemd3.2 网络与服务异常排查常见问题包括firewalld规则丢失NetworkManager与network服务冲突容器运行时cgroup驱动不匹配我的诊断脚本核心部分# 检查防火墙规则是否幸存 diff (iptables-save) /backup/iptables.rules # 验证容器运行时 podman info | grep cgroup if [ $? -ne 0 ]; then echo 可能需要更新容器配置 sed -i s/systemd/cgroupfs/ /etc/containers/containers.conf fi4. 性能调优与新特性适配24.03 LTS引入了多项底层改进需要针对性优化4.1 内核参数调整对比新旧版本的内核默认值变化参数20.03默认值24.03默认值建议调整vm.swappiness6030数据库服务器设为10net.ipv4.tcp_keepalive_time7200300根据应用场景调整fs.file-max7941689223372036854775807保持默认即可优化命令示例echo vm.swappiness10 /etc/sysctl.d/99-production.conf sysctl -p /etc/sysctl.d/99-production.conf4.2 开发环境迁移指南对于开发团队需要特别注意GCC从7.3升级到12.3带来的ABI变化Python默认版本变更导致的虚拟环境失效OpenJDK的证书存储路径调整Python虚拟环境迁移示例# 旧环境备份 pip freeze requirements.txt # 新建24.03环境 python3.11 -m venv /opt/new_venv source /opt/new_venv/bin/activate pip install -r requirements.txt # ABI兼容性检查 debuginfo-install python3-libs abi-compliance-checker -lib python3 -old 20.03 -new 24.03这场升级战役最终以零停机时间、零数据丢失的结果收官。最深刻的体会是大版本升级不是技术问题而是风险管理工程。每个生产环境都有其独特性希望我的这些实战记录能帮你少走弯路。

相关文章:

从20.03 SP3到24.03 LTS:我的openEuler大版本升级实战与避坑全记录

从20.03 SP3到24.03 LTS:我的openEuler大版本升级实战与避坑全记录 去年夏天,当我第一次在服务器监控面板上看到"openEuler 20.03-LTS-SP3即将停止维护"的警告时,就知道一场硬仗要来了。作为团队里负责基础设施的"老运维"…...

VisionPro 9.6 搭配图漾PS800-E1相机:从环境部署到第一个3D点云显示的完整避坑指南

VisionPro 9.6与图漾PS800-E1相机实战:从零构建3D点云应用的完整指南 当机器视觉工程师第一次拿到图漾PS800-E1双目散斑相机和VisionPro软件时,往往会面临一系列环境配置和调试的挑战。本文将带你从硬件连接到第一个3D点云显示的完整流程,避开…...

PixelMentor:一个开源网站 · 调用AI视觉能力分析图片 · 提供影视后期修改意见偶

1. 前言 本文详细介绍如何使用 kylin v10 iso 文件构建出 docker image,docker 版本为 20.10.7。 2. 构建 yum 离线源 2.1. 挂载 ISO 文件 mount Kylin-Server-V10-GFB-Release-030-ARM64.iso /media 2.2. 添加离线 repo 文件 在/etc/yum.repos.d/下创建kylin-local…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---命令解析和工具映射寡

先回顾:三次握手(建立连接)核心流程(实际版) 为了让挥手流程衔接更顺畅,咱们先快速回顾三次握手的实际核心,避免上下文脱节: 第一步(客户端→服务器)&#xf…...

**发散创新:用Python构建高可扩展的BI分析流水线——从数据清洗到可视化全流程实战**在现代企业数字化转型中,**商业

发散创新:用Python构建高可扩展的BI分析流水线——从数据清洗到可视化全流程实战 在现代企业数字化转型中,商业智能(BI)分析已成为决策的核心驱动力。传统的BI工具如Power BI、Tableau虽然强大,但在定制化、自动化和实…...

大卫小东(Sheldon)难

Issue 概述 先来看看提交这个 Issue 的作者是为什么想到这个点子的,以及他初步的核心设计概念。?? 本 PR 实现了 Apache Gravitino 与 SeaTunnel 的集成,将其作为非关系型连接器的外部元数据服务。通过 Gravitino 的 REST API 自动获取表结构和元数据&…...

Vue3项目实战:5分钟搞定DWG文件在线预览(VisualizeJS+VSF流)

Vue3DWG文件在线预览实战:VisualizeJS与VSF流的高效集成指南 在工业设计、建筑规划和机械制造领域,DWG文件作为AutoCAD的标准格式,其在线预览需求日益增长。传统解决方案往往依赖专业桌面软件或复杂的服务端渲染,而现代Web技术已经…...

Harness:从智能交付平台到AI工程化范式的演进

Harness:从智能交付平台到AI工程化范式的演进 在人工智能与软件工程深度交融的今天,“Harness”一词已超越了其“马具”的本意,演变为一个承载着双重含义的关键术语。它既指向一个具体的、以AI驱动的软件交付平台,也代表了一套构建和管理AI智能体(Agent)的全新工程化范式…...

存储那么贵,何不白嫖飞书云文件空间导

基础示例:单工作表 Excel 转 TXT 以下是将一个 Excel 文件中的第一个工作表转换为 TXT 的完整步骤: 1. 加载并读取Excel文件 from spire.xls import * from spire.xls.common import * workbook Workbook() workbook.LoadFromFile("示例.xlsx"…...

C# 面试高频题:装箱和拆箱是如何影响性能的?味

OCP原则 ocp指开闭原则,对扩展开放,对修改关闭。是七大原则中最基本的一个原则。 依赖倒置原则(DIP) 什么是依赖倒置原则 核心是面向接口编程、面向抽象编程, 不是面向具体编程。 依赖倒置原则的目的 降低耦合度&#…...

【大模型工程化核心瓶颈】:提示词版本失控正在拖垮你的AI交付效率?

第一章:提示词版本失控:大模型工程化中的隐形效率杀手 2026奇点智能技术大会(https://ml-summit.org) 在大模型落地实践中,提示词(Prompt)已从实验性文本演变为关键生产资产——其质量、复用性与可维护性直接决定推理…...

DBeaver连接TDengine实战:从驱动配置到时序数据查询

1. 为什么选择DBeaver管理TDengine? 作为一个长期和数据打交道的开发者,我试过不下十款数据库管理工具,最终发现DBeaver在操作时序数据库时特别顺手。你可能听说过TDengine这个国产时序数据库,它在处理物联网设备数据、监控指标这…...

第六章:Linux容器与虚拟化技术

...

别再踩坑了!保姆级教程:用PHPStudy在Win10上搞定Webug4.0靶场(附Navicat连接避坑指南)

别再踩坑了!保姆级教程:用PHPStudy在Win10上搞定Webug4.0靶场(附Navicat连接避坑指南) Webug4.0作为国内知名的Web漏洞练习靶场,是网络安全初学者提升实战能力的绝佳工具。但在Windows 10环境下使用PHPStudy搭建时&…...

从零到一:手把手教你搭建Doxygen自动化文档生成环境

1. 为什么你需要Doxygen自动化文档 第一次接手老项目代码时,看着密密麻麻的源文件却找不到函数调用关系,这种经历我太熟悉了。上周团队新来的实习生盯着屏幕发呆三小时,就为了理清一个模块的接口定义——这正是我们需要自动化文档工具的原因。…...

Playwright + MCP:AI驱动的浏览器自动化革命,告别脚本编写时代!

1. Playwright与MCP:浏览器自动化的新范式 还记得那些为了调试一个登录按钮的XPath选择器而熬到凌晨的日子吗?传统浏览器自动化就像是用螺丝刀组装汽车——效率低下且容易出错。而Playwright与MCP的结合,就像是给自动化测试装上了自动驾驶系统…...

Akagi:终极雀魂AI辅助工具完整使用指南

Akagi:终极雀魂AI辅助工具完整使用指南 【免费下载链接】Akagi 支持雀魂、天鳳、麻雀一番街、天月麻將,能夠使用自定義的AI模型實時分析對局並給出建議,內建Mortal AI作為示例。 Supports Majsoul, Tenhou, Riichi City, Amatsuki, with the …...

Codesys可视化界面设计:从零开始用按钮和指示灯搭建你的第一个HMI面板(附变量关联避坑指南)

Codesys可视化界面设计:从零开始用按钮和指示灯搭建你的第一个HMI面板(附变量关联避坑指南) 第一次接触Codesys的可视化界面设计,难免会被各种参数和选项搞得晕头转向。作为工业自动化领域的标准开发环境,Codesys提供了…...

终极指南:Hotkey Detective - 3步揪出Windows热键冲突的“幕后黑手“

终极指南:Hotkey Detective - 3步揪出Windows热键冲突的"幕后黑手" 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-d…...

STM32+EC800M-CN 4G模块数据透传踩坑实录:从AT指令调试到花生壳内网穿透

STM32与EC800M-CN 4G模块实战:从AT指令调试到内网穿透的完整指南 在物联网设备开发中,稳定可靠的数据传输是核心需求之一。本文将分享如何基于STM32微控制器和移远EC800M-CN 4G模块构建一个完整的数据透传系统,包括从硬件连接到软件调试的全过…...

模型剪枝不是“砍参数”!12篇顶会论文验证的4类结构化剪枝失效场景,90%团队正在踩坑

第一章:大模型工程化中的模型剪枝技术 2026奇点智能技术大会(https://ml-summit.org) 模型剪枝是大模型工程化落地的关键压缩技术之一,旨在在保持推理精度基本不变的前提下,系统性地移除冗余参数或结构,从而显著降低模型体积、内…...

终极进阶指南:3大维度深度优化ControlNet-v1-1_fp16_safetensors性能瓶颈

终极进阶指南:3大维度深度优化ControlNet-v1-1_fp16_safetensors性能瓶颈 【免费下载链接】ControlNet-v1-1_fp16_safetensors 项目地址: https://ai.gitcode.com/hf_mirrors/comfyanonymous/ControlNet-v1-1_fp16_safetensors ControlNet-v1-1_fp16_safete…...

番茄小说下载器:3步构建永久个人数字图书馆的终极指南

番茄小说下载器:3步构建永久个人数字图书馆的终极指南 【免费下载链接】fanqienovel-downloader 下载番茄小说 项目地址: https://gitcode.com/gh_mirrors/fa/fanqienovel-downloader 在网络小说阅读的世界里,你是否曾经历过这样的困扰&#xff1…...

nRF52840 BLE 多服务开发中的 NRF_ERROR_NO_MEM 排查与解决实战

问题现象 在基于 nRF5 SDK 的 Heart Rate 示例上添加自定义 LBS(LED Button Service)私有服务后,程序启动后立即进入 Fatal Error → System Reset 循环,串口反复打印: textapp: ble_lbs_init failed! Error code 0x0…...

MedGemma-1.5-4B实战指南:医学影像报告一致性校验与AI辅助修订系统

MedGemma-1.5-4B实战指南:医学影像报告一致性校验与AI辅助修订系统 1. 系统概述与核心价值 MedGemma Medical Vision Lab是一个基于Google MedGemma-1.5-4B多模态大模型构建的医学影像智能分析Web系统。这个系统通过直观的Web界面,让医学研究者和教育工…...

手把手教你调用MinerU API:实现多模态文档理解与自动化信息提取

手把手教你调用MinerU API:实现多模态文档理解与自动化信息提取 1. 引言 1.1 文档智能化的时代需求 在日常工作和科研中,我们经常需要处理大量非结构化文档——PDF报告、扫描合同、学术论文、财务报表等。传统的人工处理方式不仅效率低下,…...

光电对抗:多模/复合制导及其集成技术(2)

第二节:复合制导集成技术进展和前沿及攻关方向和趋势多模复合制导的集成、协调、协同技术进展,以及高效、协同、低成本的发展方向,是该领域的核心和前沿。一、集成协同技术前沿进展多模复合制导的“集成、协调、协同”,其核心是让…...

XXMI启动器技术架构解析与跨平台插件管理系统

XXMI启动器技术架构解析与跨平台插件管理系统 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher XXMI启动器是一款基于Python构建的跨平台插件管理系统,为现代应用提供统…...

Golang 任务调度与优先级队列实战:从能跑到生产可用

Golang 任务调度与优先级队列实战:从能跑到生产可用 关键词:Golang、任务调度、优先级队列、Worker Pool、延迟任务、重试退避、优先级老化、高并发、可观测性、分布式演进 很多团队第一次做“任务调度系统”时,往往只做到了“能把任务跑起来”。上线后才发现,真正难的不是…...

把 Agent 接入真实系统前必须做的 12 项风控:权限、审计、隔离、限流

当AI助手闯真实业务:从0到1落地Agent的12项生死线风控清单 关键词 Agent接入风控、Agent权限分层、Agent审计追踪、Agent资源隔离、Agent动态限流、Agent幻觉过滤、Agent意图识别、Agent合规校验、Agent回滚机制、Agent应急熔断、Agent多Agent协作约束、Agent身份认证与权限…...