mysql: /lib64/libstdc++.so.6: version `GLIBCXX_3.4.21‘ not found解决

  不记得什么时候升级了gcc,然后启动MySQL的时候就报错了:/usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.21’ not found。原因是升级gcc时,生成的动态库没有替换老版本gcc的动态库导致的,将gcc最新版本的动态库替换系统中老版本的动态库即可解决。(叙述来源

1. 错误分析

[root@chengyu ~]# mysql -uroot -p --prompt="mysql:[\d] \\R:\\m:\\s> "
node: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.21' not found (required by node)
node: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.15' not found (required by node)
node: /usr/lib64/libstdc++.so.6: version `GLIBCXX_3.4.20' not found (required by node)

  检查动态库:

[root@chengyu ~]# strings /usr/lib64/libstdc++.so.6 | grep GLIBC
GLIBCXX_3.4
GLIBCXX_3.4.1
GLIBCXX_3.4.2
GLIBCXX_3.4.3
GLIBCXX_3.4.4
GLIBCXX_3.4.5
GLIBCXX_3.4.6
GLIBCXX_3.4.7
GLIBCXX_3.4.8
GLIBCXX_3.4.9
GLIBCXX_3.4.10
GLIBCXX_3.4.11
GLIBCXX_3.4.12
GLIBCXX_3.4.13
GLIBCXX_3.4.14
GLIBCXX_3.4.15
GLIBCXX_3.4.16
GLIBCXX_3.4.17
GLIBCXX_3.4.18
GLIBCXX_3.4.19
GLIBC_2.3
GLIBC_2.2.5
GLIBC_2.14
GLIBC_2.4
GLIBC_2.3.2
GLIBCXX_DEBUG_MESSAGE_LENGTH

  从以上输出可以看出,gcc的动态库还是旧版本GLIBCXX_3.4.19的,下面针对性解决问题。

2. 解决问题

  查找编译gcc时生成的最新动态库:

[root@chengyu ~]# find / -name "libstdc++.so*"
/usr/lib/libstdc++.so.6
/usr/lib/libstdc++.so.6.0.19
/usr/lib/libstdc++.so.5
/usr/lib/libstdc++.so.5.0.7
/usr/lib64/libstdc++.so.6
/usr/lib64/libstdc++.so.6.0.19
/usr/lib64/libstdc++.so.5
/usr/lib64/libstdc++.so.5.0.7
/usr/local/gcc-9.2.0/lib64/libstdc++.so.6.0.27
/usr/local/gcc-9.2.0/lib64/libstdc++.so.6
/usr/local/gcc-9.2.0/lib64/libstdc++.so
/usr/local/gcc-9.2.0/lib64/libstdc++.so.6.0.27-gdb.py
……

  /usr/local/gcc-9.2.0/lib64/是升级gcc时的输出路径,将最新动态库libstdc++.so.6.0.27复制到/usr/lib64路径下:

[root@chengyu ~]# cp /usr/local/gcc-9.2.0/lib64/libstdc++.so.6.0.27 /usr/lib64

  重建默认库的软连接:

[root@chengyu ~]# cd /usr/lib64
[root@chengyu lib64]# ll
[root@chengyu lib64]# rm -rf libstdc++.so.6
[root@chengyu lib64]# ln -s libstdc++.so.6.0.27 libstdc++.so.6

  检查动态库升级完情况:

[root@chengyu lib64]# strings /usr/lib64/libstdc++.so.6 | grep GLIBC
GLIBCXX_3.4
GLIBCXX_3.4.1
GLIBCXX_3.4.2
GLIBCXX_3.4.3
GLIBCXX_3.4.4
GLIBCXX_3.4.5
GLIBCXX_3.4.6
GLIBCXX_3.4.7
GLIBCXX_3.4.8
GLIBCXX_3.4.9
GLIBCXX_3.4.10
GLIBCXX_3.4.11
GLIBCXX_3.4.12
GLIBCXX_3.4.13
GLIBCXX_3.4.14
GLIBCXX_3.4.15
GLIBCXX_3.4.16
GLIBCXX_3.4.17
GLIBCXX_3.4.18
GLIBCXX_3.4.19
GLIBCXX_3.4.20
GLIBCXX_3.4.21
GLIBCXX_3.4.22
GLIBCXX_3.4.23
GLIBCXX_3.4.24
GLIBCXX_3.4.25
GLIBCXX_3.4.26
GLIBCXX_3.4.27

  再试试MySQL:

[root@chengyu lib64]# mysql -uroot -p --prompt="mysql:[\d] \\R:\\m:\\s> "
Enter password:

  OK了!

  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值