简析Oracle数据库常见问题及解决方案
Oracle数据库在使用的过程中常常会遇到这样或那样的问题,而这些问题常常又使我们感到很困惑,本文我们总结了Oracle数据库在使用过程中的一些问题,并给出了解决方法,下面我们就开始分析一下这些问题。
一、oracle监听启动后,立即停止。
TNS-12545:因目标主机或对象不存在,连接失败。
TNS-12560:TNS:协议适配器错误。
TNS-00515:因目标主机或对象不存在,连接失败。
32-bitWindowsError:1004:Unknownerror。
不再监听:(DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(PIPENAME=//./pipe/EXTPROC0ipc)))。
原因是我安装了oracle之后,又修改了主机名。
解决方法:
1.直接修改listener.ora
路径是:oracle安装目录/product/10.2.0/db_1/NETWORK/ADMIN/listener.ora.
修改HOST为主机名或者IP.
2.通过NetManager,在监听程序/LISTENER下直接修改主机即可
二.错误码及解决办法
1.ORA:-12545:因目标主机和对象不存在,连接失败。
错误代码ORA-12545表示网络连接串(即tnsnames.ora文件中的HOST处)中使用的机器名和IP地址不存在,重新修改和重新连接即可。
2.ORA-12651:TNS:没有监听器。
该信息说明所要连接的服务器没有启动监听进程Listener(该进程为Oracle服务器上操作系统进程,监听进程没有启动时,服务器可以正常进行,但是客户端不能与服务器产生连接。这时可以在服务器使用操作系统命令lsnrctl正常起启动监听进程)。
3.ORA-00600:internalerrorcode,arguments:[num],[?],[?],[?],[?]。
产生原因:这种错误通常为ORACLE的内部错误,只对OSS和ORACLE开发有用。ORA-600的错误经常伴随跟踪文件的状态转储(系统状态和进程状态),系统状态存储将包括ORACLERDBMS持有的当前对象的信息,进程状态转储则将显示特殊进程持有的对象,当进程符合了某错误条件时,经常是由于一些信息取自它持有的一个块,如果我们知道这些错误进程持有的块,就容易跟踪问题的来源。
解决方法:一般来说出现这个错误我们本身是无法解决的,只有从提高系统本身各方面来解决这个内部问题,如增加硬件设备,调整系统性能,使用OPS(当然OPS从某种意义上说并不是一种好的解决方式)等。ORA-600错误的第一个变量用于标记代码中错误的位置(代码中的每个部分的第一变量都不一样),从第二个到第五个变量显示附加信息,告诉OSS代码在哪里出现了错误
4.ORA-12560 协议适配器错误:
有关ORA-12560:TNS:协议适配器错误的问题
①.检查TerminalService,远程桌面是不是起因。
②.环境变量setoracle_sid=需要的服务名。
③.listener.ora,tnsnames.ora等内机器名或者IP地址是否正确。
④.netstat–a检查端口是否被占用。
⑤.检查注册表HKEY_LOCAL_MACHINE/Software/Oracle/Home0新增字符串USE_SHARED_SOCKET=TRUE,重新启动服务。
5.ORA-28595:InvalidDLLPath 调用外部DLL出错
原因:AsettinginOracle'sLISTENER.ORAfileontheserverhostingtheRDBMSismissing.
解决办法:
(1).LocatetheactiveLISTENER.ORAfileontheserver. Bydefault,itwillbeontheOracleRDBMSdriveinthepath../ora92/network/admin.
(2).Inspectthefileandlocateallentriesassociatedwith"SID_DESC". Eachsuchentryshouldhavethefollowingoptionassociatedwithit:
(ENVS="EXTPROC_DLLS=ANY")
(3).Addtheabovelinetoanyentrywhereitismissing.
(4).RestarttheOracleListenerService(orreboottheserverwhichwillinturnrestartOracle).
例子:
TheexampleLISTENER.ORAfilebelowshowsavalidconfigurationfortheservernamed"WOODY"(usingTCP/IPonPort1521)withthecorrectENVSentrieshighlighted:
#LISTENER.ORANetworkConfigurationFile:C:/oracle/ora92/network/admin/listener.ora
#GeneratedbyOracleconfigurationtools.
LISTENER= (DESCRIPTION_LIST= (DESCRIPTION= (ADDRESS_LIST= (ADDRESS=(PROTOCOL=IPC)(KEY=EXTPROC0)) ) (ADDRESS_LIST= (ADDRESS=(PROTOCOL=TCP)(HOST=woody)(PORT=1521)) ) ) ) SID_LIST_LISTENER= (SID_LIST= (SID_DESC= (SID_NAME=PLSExtProc) (ORACLE_HOME=C:/oracle/ora92) (PROGRAM=extproc) (ENVS="EXTPROC_DLLS=ANY") ) (SID_DESC= (GLOBAL_DBNAME=WOODY) (ORACLE_HOME=C:/oracle/ora92) (SID_NAME=WOODY) (ENVS="EXTPROC_DLLS=ANY") ) )
6.在控制面板中启动服务,出现以下错误:
服务:在本地计算机无法启动OracleOraDb10g_home1TNSListener服务。
错误3:系统找不到指定的路径。
查看属性发现,OracleOraDb10g_home1TNSListener服务的可执行文件的路径为空。
解决办法:
开始-->运行REGEDIT-->进入注册表找到HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/OracleOraDb10g_home1TNSListener
发现ImagePath关键值没有了,新建一个名为ImagePath的可扩充字符串值,编辑字符串的数值数据为:Oracle安装路径/BIN/TNSLSNR
7.错误描述:本地计算机上的OracleOraDb10g_home1TNSListener服务启动后又停止了。一些服务自动停止,如果它们没有什么可做的,例如"性能日志和警报"服务。
解决办法:C:/oracle/product/10.2.0/db_1/NETWORK/ADMIN/listener.ora把这这文件里的内容改下HOST=你的计算机名字。
关于Oracle数据库的问题及解决方法就介绍到这里,希望能够对您有所帮助。