CentOS7升级Glibc到超过2.17版本无法启动的解决办法
  HL7exJhKg9j2 2023年11月02日 62 0

CentOS7升级Glibc到超过2.17版本无法启动的解决办法


背景

今天有同事告知服务器宕机无法启动.
提示信息为:
[sda] Assuming drive cache: write through
后系统没有任何反应.
一开始同事说没有做任何处理, 突然至此
我感觉比较奇怪.然后进行了一下简要处理
最终发现是gblic相关.然后在脚本之家找了一个处理方案
但是发现方案上面有一些不太明确的地方.
所以在这里总结一下完整版的处理过程和方法

问题确认

系统无法启动,第一步都是再进入系统的界面输入 "e"
然后修改 rhgb quite 变成 init=/bin/bash
(备注: rhgb = redhatgraphics boot)

进入系统后执行命令
mount -o remount,rw /sysroot
发现还有一个错误提示:
relocation error: /lib64/libc.so.6:
symbol _dl_starting_up,
version GLIBC_PRIVATE not defined
in file ld-linux-x86-64.so.2 with link time reference

至此才发现是glibc的问题导致的

glibc问题处理-long time ago

网上很多解决方案一般是说再不关机的情况下的处理.
但是减少有重启了机器后的处理
很早之前同事给centos7 安装 tfs-agent时就导致过宕机
但是当时虚拟机是新作的我也懒的去查解决方案
就重新给了一个centos8 的虚拟机了事.

话说centos 虽然非常稳定. 但是他的内核和核心组件升级
是真心的非常慢.
现在都准备过度到OpenEuler上面来.

glibc问题的处理

Study from
https://www.jb51.net/article/230473.htm

解决方案基本上照抄 就是改了一两个小细节.

glibc问题的处理

给虚拟机挂在上CentOS的ISO镜像文件.
然后重启虚拟机.

注意如果无法进入安装界面的话,可以修改虚拟机配置
在 配置界面的 选项->高级-引导选项 中选中
"虚拟机下次引导时 强制进入BIOS选项"
然后进入BIOS后修改启动顺序为CD-ROM 为第一位.

进入CentOS的安装界面(系统仅会等待60S,需要尽快处理 )
选中trobleshooting
然后进行rescue 操作系统.

glibc问题的处理

进入rescue 后 选择continue
会进入修复界面
需要说明一点. 不要按照要求进行
chroot /mnt/sysimage 的处理
不然还会无法执行相关的命令(这个root 是损坏的)
可以执行如下命令

ls -l /mnt/sysimage/lib64/glibc-*

查看对应的有问题的glibc的版本.
脚本之家里面说的是 2.18 我这边同事升级的是2.25
注意必须清理掉非2.17版本的glibc 才可以, 不然会做无用功.
需要针对不通版本进行清理.

rm -rf /mnt/sysimage/lib64/*2.25*

# 注意这一步必须按照上一步的版本来, 不然无效.

glibc问题的处理

重新安装glibc
方法比较简单
在rescue的界面下
mkdir /rpm
mount /dev/cdrom /rpm
cd /rpm/Packages/
执行命令
rpm -ivh --force --root=/mnt/sysimage glibc*
# 注意这个命令里面 --root 是核心命令. 指定往哪个挂载目录执行命令.

重启验证

重启一般可以进入图形界面
但是其他组件比如sshd 或者是升级了glibc 后又安装的软件可能无法使用
需要单独在处理.



【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月08日 0

暂无评论

推荐阅读
  9E2BTpjt8nym   2023年12月06日   36   0   0 WindowsgitCentOS
HL7exJhKg9j2