记一次 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无法连接 问题分析的主要内容,如果未能解决你的问题,请参考以下文章

记一次sqlserver连接Oracle

记一次centos7主机名变bogon导致ORACLE无法远程访问的经历(原创)

记一次ORACLE的UNDO表空间爆满分析过程

记一次ORACLE无法启动登陆事故

记一次Oracle启动报错问题解决

记一次oracle crs无法重启事故