记一次 Oracle无法连接 问题分析
Posted dotNET跨平台
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了记一次 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
返回如下错误:
可以确定了,启动参数有问题,导致数据库并未启动成功!
解决方法
由于我们没有改过任何参数,而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“
以上是关于记一次 Oracle无法连接 问题分析的主要内容,如果未能解决你的问题,请参考以下文章