OpenSSH【安装 02】离线升级异常问题解决、无法升级时的失败恢复

本文记录了OpenSSL离线升级过程中遇到的常见问题及解决方案。主要包括:

  • 1)"Can't locate IPC/Cmd.pm"错误,通过强制安装rpm包解决依赖问题;
  • 2)Python版本冲突问题,通过重新安装Python 2.7.5解决依赖关系;
  • 3)升级失败后的恢复方法,需重新安装原始版本的openssh相关rpm包。

分享了解决问题所需的安装包资源,包括Python依赖文件和SSH恢复文件,存放在百度网盘供下载使用。

1.异常问题

1.1 Can't locate IPC/Cmd.pm in @INC

以下是在安装 openssl-3.2.0时的报错信息,内容如下,其中 /home/sshupdate/openssl-3.2.0/为安装包的解压目录:

bash 复制代码
Can't locate IPC/Cmd.pm in @INC (@INC contains: /home/sshupdate/openssl-3.2.0/util/perl /usr/local/lib64/perl5 /usr/local/share/perl5 /usr/lib64/perl5/vendor_perl /usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5 . /home/sshupdate/openssl-3.2.0/external/perl/Text-Template-1.56/lib) at /home/sshupdate/openssl-3.2.0/util/perl/OpenSSL/config.pm line 19.
BEGIN failed--compilation aborted at /home/sshupdate/openssl-3.2.0/util/perl/OpenSSL/config.pm line 19.
Compilation failed in require at /home/sshupdate/openssl-3.2.0/Configure line 23.
BEGIN failed--compilation aborted at /home/sshupdate/openssl-3.2.0/Configure line 23.

问题原因是上篇《OpenSSH 漏洞修复》在离线安装 perl-CPAN perl-ExtUtils-CBuilder perl-ExtUtils-MakeMaker时命令使用的是:

bash 复制代码
rpm -ivh *.rpm

次命令无法处理安装包之间的依赖关系,导致安装中断,使用以下命令解决了这个问题:

bash 复制代码
rpm -ivh --force *.rpm

1.2 python(abi) = 2.7 被 xxx-xxx.el7.noarch 需要

  1. 问题说明
bash 复制代码
警告:gdbm-devel-1.10-8.el7.x86_64.rpm: 头V3 RSA/SHA256 Signature, 密钥 ID f4a80eb5: NOKEY
错误:依赖检测失败:
        python(abi) = 2.7 被 pyparsing-1.5.6-9.el7.noarch 需要
        /usr/bin/python2 被 systemtap-sdt-devel-4.0-13.el7.x86_64 需要

当前问题是在安装依赖文件时就报错了,后来发现当前的 Python 是自行解压安装的 2.7.5版本,安装目录非 /usr/bin/尝试的解决方法:

  • (失败)使用软连接 ln -s /usr/local/bin/python2.7 /usr/bin/python2依然报错。
  • (成功)使用 rpm 包离线安装 Python2.7.5
  1. 解决方法

离线安装过程:

bash 复制代码
# 先安装Pyhton依赖
rpm -ivh python-libs-2.7.5-89.el7.x86_64.rpm
# 然后安装Python环境
rpm -ivh python-2.7.5-89.el7.x86_64.rpm

安装后的版本查看:

bash 复制代码
# 安装包上的版本号明明是2.7.5为什么会显示2.7.15?
Python 2.7.15

安装 Python 后,后续的安装流程正常。

2.失败恢复

升级失败后发现一个问题,之前的备份不可用,仅仅进行以下操作是无效的:

bash 复制代码
cp -r /etc/ssh.old /etc/ssh
cp -p /usr/bin/ssh.bak /usr/bin/ssh
cp -p /usr/sbin/sshd.bak /usr/sbin/sshd
cp -p /usr/bin/ssh-keygen.bak /usr/bin/ssh-keygen

需要重新安装卸载的 3 个 rpm 包:

  • openssh-7.4p1-21.el7.x86_64.rpm
  • openssh-clients-7.4p1-21.el7.x86_64.rpm
  • openssh-server-7.4p1-21.el7.x86_64.rpm

3.文件分享

通过网盘分享的文件:CSDN_OpenSSH_恢复 链接: pan.baidu.com/s/1cxZigSHf... 提取码: bcbm

  • 文件夹解决 Python2 问题包含以下文件
  • 文件夹失败恢复文件包含以下文件

4.小小的总结

OpenSSH的升级是个绕不开的话题,漏洞补了漏、漏了补,升级失败不算大问题,也不是小问题。

相关推荐
IT_陈寒26 分钟前
Python开发者必知的5大性能陷阱:90%的人都踩过的坑!
前端·人工智能·后端
流浪克拉玛依1 小时前
Go Web 服务限流器实战:从原理到压测验证 --使用 Gin 框架 + Uber Ratelimit / 官方限流器,并通过 Vegeta 进行性能剖析
后端
孟沐1 小时前
保姆级教程:手写三层架构 vs MyBatis-Plus
后端
星浩AI1 小时前
让模型自己写 Skills——从素材到自动生成工作流
人工智能·后端·agent
华仔啊4 小时前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
武子康4 小时前
大数据-242 离线数仓 - DataX 实战:MySQL 全量/增量导入 HDFS + Hive 分区(离线数仓 ODS
大数据·后端·apache hive
砍材农夫5 小时前
TCP和UDP区别
后端
千寻girling5 小时前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
千寻girling6 小时前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
贾铭6 小时前
如何实现一个网页版的剪映(三)使用fabric.js绘制时间轴
前端·后端