记一次 Oracle无法连接 问题分析

前言

今天,同事告诉我,有台Oracle服务器异常断电,重启后发现无法连接了。

分析过程

1.检查服务状态

查看Oracle的listerner服务和service服务,发现都是正在运行状态,说明服务是正常的。

2.检查端口状态

在客户机上使用:

tnsping 服务器IP:1521

返回OK,说明端口也是正常的。

3.检查日志

检查Oracle安装目录下的所有log文件,最后在“D:\app\Administrator\product\11.2.0\dbhome_1\database\oradim.log”下发现如下内容:

D:\app\Administrator\product\11.2.0\dbhome_1\bin\oradim.exe -startup -sid orcl -usrpwd * -log oradim.log -nocheck 0

ORA-00119: invalid specification for system parameter LOCAL_LISTENER 

ORA-00132: syntax error or unresolved network name 'LISTENER_ORCL'

感觉找到错误根源了。

4.检查数据库启动状态

于是,在服务器上验证数据库是否启动成功,运行下列命令:

sqlplus / as sysdba
SQL>startup

返回如下错误:

313e0804947d46981d376c9dd498c139.png

可以确定了,启动参数有问题,导致数据库并未启动成功!

解决方法

由于我们没有改过任何参数,而Oracle默认使用spfile启动,因此先尝试使用pfile启动:

SQL>startup pfile='D:\app\Administrator\orcl\pfile\init.ora.1223201617822

pfile和spfile的区别请自行百度

发现启动成功,并且客户端可以正常连接了。

于是怀疑是spfile文件损坏,使用下列命令重建spfile:

SQL> create spfile from pfile;

重启服务后,一切恢复正常!

结论

刚开始陷入了经验误区,认为服务启动了数据库就是正常工作的,导致走了一些弯路。

如果你觉得这篇文章对你有所启发,请关注我的个人公众号”My IO“

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值