前言
今天,同事告诉我,有台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“