欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

简析Oracle数据库常见问题及解决方案

程序员文章站 2022-08-04 16:27:51
oracle数据库在使用的过程中常常会遇到这样或那样的问题,而这些问题常常又使我们感到很困惑,本文我们总结了oracle数据库在使用过程中的一些问题,并给出了解决方法,下面...

oracle数据库在使用的过程中常常会遇到这样或那样的问题,而这些问题常常又使我们感到很困惑,本文我们总结了oracle数据库在使用过程中的一些问题,并给出了解决方法,下面我们就开始分析一下这些问题。

一、oracle监听启动后,立即停止。

tns-12545: 因目标主机或对象不存在,连接失败。

tns-12560: tns: 协议适配器错误。

tns-00515: 因目标主机或对象不存在,连接失败。

32-bit windows error: 1004: unknown error。

不再监听: (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.通过 net manager,在 监听程序/listener 下直接修改主机即可 

二.错误码及解决办法

1.ora:-12545:因目标主机和对象不存在,连接失败。

错误代码ora-12545表示网络连接串(即tnsnames.ora文件中的host处)中使用的机器名和ip地址不存在,重新修改和重新连接即可。

2.ora-12651:tns:没有监听器。

该信息说明所要连接的服务器没有启动监听进程listener(该进程为oracle服务器上操作系统进程,监听进程没有启动时,服务器可以正常进行,但是客户端不能与服务器产生连接。这时可以在服务器使用操作系统命令lsnrctl正常起启动监听进程)。

3.ora-00600:internal error code,arguments:[num],[?],[?],[?],[?] 。

产生原因:这种错误通常为oracle的内部错误,只对oss和oracle开发有用。ora-600的错误经常伴随跟踪文件的状态转储(系统状态和进程状态),系统状态存储将包括oracle rdbms持有的当前对象的信息,进程状态转储则将显示特殊进程持有的对象,当进程符合了某错误条件时,经常是由于一些信息取自它持有的一个块,如果我们知道这些错误进程持有的块,就容易跟踪问题的来源。

解决方法:一般来说出现这个错误我们本身是无法解决的,只有从提高系统本身各方面来解决这个内部问题,如增加硬件设备,调整系统性能,使用ops(当然ops从某种意义上说并不是一种好的解决方式)等。ora-600错误的第一个变量用于标记代码中错误的位置(代码中的每个部分的第一变量都不一样),从第二个到第五个变量显示附加信息,告诉oss代码在哪里出现了错误

4.ora-12560  协议适配器错误:

有关ora-12560: tns:协议适配器错误的问题

①.检查terminal service, 远程桌面是不是起因。

②.环境变量set oracle_sid=需要的服务名。

③.listener.ora, tnsnames.ora等内机器名或者ip地址是否正确。

④.netstat –a检查端口是否被占用。

⑤.检查注册表hkey_local_machine/software/oracle/home0新增字符串use_shared_socket=true, 重新启动服务。

5.ora-28595: invalid dll path   调用外部dll出错

原因:a setting in oracle's listener.ora file on the server hosting the rdbms is missing.

解决办法:

(1).locate the active listener.ora file on the server.  by default, it will be on the oracle rdbms drive in the path ../ora92/network/admin.

(2).inspect the file and locate all entries associated with "sid_desc".  each such entry should have the following option associated with it:

(envs = "extproc_dlls=any")

(3).add the above line to any entry where it is missing.

(4).restart the oracle listener service (or reboot the server which will in turn restart oracle).

例子:

the example listener.ora file below shows a valid configuration for the server named "woody" (using tcp/ip on port 1521) with the correct envs entries highlighted:

# listener.ora network configuration file: c:/oracle/ora92/network/admin/listener.ora

# generated by oracle configuration tools.

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数据库的问题及解决方法就介绍到这里,希望能够对您有所帮助。