CentOS8静默安装Oracle11g:lsnrctl、tnsping等文件大小为0的问题

背景

平台版本
操作系统centOS 8
Oracle11.2.0.1

故障现象

数据库软件安装完毕,并创建了监听。但在启动监听时,命令一跳而过,不报错,无反应。且文件大小为0。

[oracle@s1 bin]$ lsnrctl start
[oracle@s1 bin]$

同时,其他内部工具如tnsping、impdp、expdp等都有相同情况。

原理

数据库软件安装的有问题。
因为是采用的静默方式,命令行反馈的消息基本无价值。实际已经安装失败了,但没有发现。
实际报错信息包含在了详细日志里:

INFO: ----------------------------------
INFO: 

INFO: /bin/chmod 755 /home/oracle/app/product/112010/db_1/bin/

INFO:  - Linking tnslsnr
rm -f tnslsnr
gcc -o tnslsnr -m64 -L/home/oracle/app/product/112010/db_1/network/lib/ -L/home/oracle/app/product/112010/db_1/lib/ -L/home/oracle/app/product/112010/db_1/lib/stubs/  /home/oracle/app/product/112010/db_1/network/lib/s0nsgl.o /home/oracle/app/product/112010/db_1/network/lib/snsglp.o -lclntsh  `cat /home/oracle/app/product/112010/db_1/lib/ldflags`    -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lnro11 `cat /home/oracle/app/product/112010/db_1/lib/ldflags`    -lncrypt11 -lnsgr11 
INFO: -lnzjs11 -ln11 -lnl11 -lnnz11 -lzt11 -lztkg11 -lztkg11 -lclient11 -lnnetd11  -lvsn11 -lcommon11 -lgeneric11 -lmm -lsnls11 -lnls11  -lcore11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lxml11 -lcore11 -lunls11 -lsnls11 -lnls11 -lcore11 -lnls11 `cat /home/oracle/app/product/112010/db_1/lib/ldflags`    -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lnro11 `cat /home/oracle/app/product/112010/db_1/lib/ldflags`    -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lclient11 -lnnetd11  -lvsn11 -lcommon11 -lgeneric11   -lsnls
INFO: 11 -lnls11  -lcore11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lxml11 -lcore11 -lunls11 -lsnls11 -lnls11 -lcore11 -lnls11 -lclient11 -lnnetd11  -lvsn11 -lcommon11 -lgeneric11 -lsnls11 -lnls11  -lcore11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lxml11 -lcore11 -lunls11 -lsnls11 -lnls11 -lcore11 -lnls11   `cat /home/oracle/app/product/112010/db_1/lib/sysliblist` -Wl,-rpath,/home/oracle/app/product/112010/db_1/lib -lm    `cat /home/oracle/app/product/112010/db_1/lib/sysliblist` -ldl -lm   -L/home/oracle/ap
INFO: p/product/112010/db_1/lib -lons -lnl11  -ln11 -lnlsnr11 -lnlsnrc11 -lnsgr11 -lnms -lncm11 -lnmsp -lpeer -lnro11 -ln11   -lnl11 -lnlsnr11 -lnlsnrc11 -lnms -lncm11 -lnmsp -ln11     -lm 

INFO: //usr/lib64/libaio.so.1: undefined reference to `__stack_chk_fail@GLIBC_2.4
INFO: '
collect2: error: ld returned 1 exit status
make: *** [/home/oracle/app/product/112010/db_1/network/lib/ins_net_server.mk:29: tnslsnr] Error 1

INFO: End output from spawned process.
INFO: ----------------------------------

解决方法

居然是用gcc编译实现的安装,关键报错信息是:

INFO: //usr/lib64/libaio.so.1: undefined reference to `__stack_chk_fail@GLIBC_2.4

对于oracle11g 的安装, libaio1库版本不能大于0.3.109
libaio1.so.1文件不依赖与任何其他库,本质就是一个独立的so文件,我们直接替换即可。
可用的libaio.so文件可在本处下载。

查看centos8的是0.3.110了,比要求的版本高。

[oracle@s3 install]$ rpm -qa libaio
libaio-0.3.110-12.el8.x86_64

下载合适的so文件,并重建libaio.so.1的软链接
注意:新so文件的大小是5256,自带文件的大小是16248。

[oracle@s3 admin]$ cd /usr/lib64
ln -sf libaio.so.1.0.1.new libaio.so.1
[oracle@s3 lib64]$ ll libaio*
lrwxrwxrwx. 1 root root    19 Jan 12 11:05 libaio.so.1 -> libaio.so.1.0.1.new
-rwxr-xr-x. 1 root root 16248 May 11  2019 libaio.so.1.0.0
-rwxr-xr-x. 1 root root 16248 May 11  2019 libaio.so.1.0.1
-rw-r--r--. 1 root root  5256 Jan 12 11:04 libaio.so.1.0.1.new

图形化安装下,也一样出现该问题,但是会有提示,更容易发现一些。

参考

1.可用版本的下载地址:https://www.cnblogs.com/jinzhenshui/p/9366002.html
2.https://blog.csdn.net/pacificyang/article/details/110952123

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值