Oracle数据库TNS常见错误解决方法1、ORA-12541:TNS:没有监听器
原因:没有启动监听器或者监听器损坏。若是前者,使用命令net start OracleOraHome10gTNSListener(名字可能有出入)即可;如果是后者,则使用“Net Configuration Assistant”工具向导之“监听程序配置”增加一个监听器即可(基本不用写任何信息,一路OK。在添加之前可能需要把所有的监听器先删!) 2、ORA-12500:TNS:监听程序无法启动专用服务器进程或ORA-12560:TNS:协议适配器错误 原因:ORACLE的数据库服务没有启动。使用命令net start ORACLESERVICEORADB(ORADB为数据库名字)即可。如果仍没有解决,请继续向下看。 3、如果数据库服务启动失败,则很有可能是其注册表项值损坏,最好的做法是以下两步: 1)ORADIM -DELETE -SID oradb 删除数据库服务项 2)ORADIM -NEW -SID oradb 新增数据库服务项 注:这个过程中如果出错,就重启计算机! 4、ORA-12154:TNS:能解析服务名 原因:ORACLE的网络服务名没有正确配置。请使用“Net8 Configuration Assistant”工具向导之“本地网络服务名配置”配置TNS即可。如果仍没有解决,请继续向下看。 5、ORA-1034 :TNS:ORACLE不可用 原因:ORACLE的数据库服务正确启动,但是数据库没有打开! 使用命令: 1)svrmgrl 启动服务管理器 2)connect internal 以internal身份登陆 3)startup 打开数据库 6、ORA-12560:TNS:协议适配器错误(顽固性的) 原因:未知。 解决:必杀技--打开“Windows任务管理器”,杀死ORACLE.exe及ORADIM.exe进程,书写自己的ora_startup.bat,执行之! PS: 1、ora_startup.bat: net start OracleOraHome81TNSListener net start ORACLESERVICEORADB svrmgrl 一般情况下不用,不过有时少不了它的,具体步骤见第5步。 2、ora_shutdown.bat: net stop OracleOraHome81TNSListener net stop ORACLESERVICEORADB 3、ORACLE相关服务名请参见“管理工具”之“服务”中以ORACLE开头的服务名 1、TNS-12154 Error 或ORA-12154 特征:SQL*NET没有找到连接串或别名 原因1:(1)没有找到TNSNAMES.ORA文件,该文件的缺省路径为: windows 95/98 client sql*Net 2.x - ORAWIN95NETWORKADMIN Net8 - ORAWIN95NET80admin Net8i - ORACLEORA81NETWORKADMIN windows NT client sql*Net 2.x - ORANTNETWORKADMIN Net8 - ORANTNET80ADMIN Net8i - ORACLEORA81NETWORKADMIN UNIX Client $ORACLE_HOME/NETWORK/ADMIN or /etc or /var/opt/oracle . 在客户端设置TNS_ADMIN 在注册表 HKEY_LOCAL_MACHINESoftwareOracle 设置TNS_ADMIN. TNS_ADMIN 指向TNSNAMES.ORA文件的位置 措施:按上述说明检查文件位置 原因2:(2)TNSNAMES.ORA文件中内容格式不对 措施:检查文件格式,标准格式如下: DEV1.WORLD = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = tcp) (Host = 145.45.78.56) (Port = 1521) ) ) (CONNECT_DATA = (SID = ORCL) ) ) 原因3: (3) TNSNAMES.ORA与SQLNET.ORA不一致 措施: SQLNET.ORA格式如下: TRACE_LEVEL_CLIENT = OFF SQLNET.AUTHENTICATION_SERVICES = (NONE) NAMES.DIRECTORY_PATH = (TNSNAMES) AUTOMATIC_IPC = OFF 因为没有NAMES.DEFAULT_DOMAIN=world,所以DEV1.WORLD连接串不能连接,可以在TNSNAMES.ORA中增加 DEV1 = (DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP) (Host = 145.45.78.56) (Port = 1521) ) ) (CONNECT_DATA = (SID = ORCL) ) ) 此时可连接。 2、NL-00462 Error 或ORA-00462 特征:监听器无法启动 原因:LISTENER.ORA文件内容错误,例如,括号不匹配、参数名错误等、多余的空格等。 措施:重新编辑文件 3、NL-00405 Error 或ORA-00405 特征:LISTENER.ORA文件不可读或找不到 原因:LISTENER.ORA文件内容错误,例如,括号不匹配、参数名错误等、多余的空格等。 措施:确保文件位置在缺省目录下$ORACLE_HOME/network/admin,或设置环境变量TNS_ADMIN指向这个文件所在位置。 4、TNS-01155 Error 或ORA-01155 特征:LISTENER.ORA文件中SID_LIST_LISTENER变量赋值不对 原因:LISTENER.ORA文件内容错误,SID_LIST_LISTENER变量赋值不对。 措施:确保文件中赋值正确,$ORACLE_HOME/network/admin/samples目录下有样例文件,可供参考。 5、TNS-12537 、TNS-12560、TNS-00507 Error 特征:LISTENER.ORA文件中引用了一个无效的协议适配程序 原因:LISTENER.ORA文件中PROCOTOL变量赋值不对。 措施:确保文件中赋值正确,一般用tcp协议,$ORACLE_HOME/network/admin/samples目录下有样例文件,可供参考。用adapters tnslsnr检查协议程序 6、TNS-12203 Error 特征:不能与目标连接 原因:监听器是否启动;别名是否配置 措施:检查监听器是否启动,例如lsnrctl status;检查TNSNAMES.ORA的别名配置 7、TNS-12533 Error 特征:不能与目标连接 原因:非法的address参数, 措施:检查TNSNAMES.ORA的ADDRESS参数 1)用tnsping net_service_name测试网络服务名是否配置正确! 2)用sqlplus程序通过test网络服务名进行测试,如sqlplus system/manager@test。如果不能连接到数据库,则在tnsname.ora文件中的test网络服务名(net service)后面加上sqlnet.ora文件NAMES.DEFAULT_DOMAIN参数的值, xieyunchao 2009年03月07日 11点34分46秒 说: 我怎么看有没有问题啊。 vc555 2009年03月07日 11点39分15秒 说: 你的host内容是什么呢? xieyunchao 2009年03月07日 11点39分34秒 说: 127.0.0.1 localhost xieyunchao 2009年03月07日 11点39分45秒 说: 就这一行,其他的都是注释。 xieyunchao 2009年03月07日 11点40分11秒 说: 是hosts文件,不是host文件吧。路径是/system32/driver/ect/ xieyunchao 2009年03月07日 11点40分17秒 说: 对吧。 vc555 2009年03月07日 11点40分43秒 说: 恩。 你用sqlplus看看用localhost能连吗? xieyunchao 2009年03月07日 11点42分17秒 说: 也不行,不能用localhost,只能用192.xx. vc555 2009年03月07日 11点42分14秒 说: 还有,用127.0.0.1能连吗? xieyunchao 2009年03月07日 11点42分30秒 说: 不能连 vc555 2009年03月07日 11点42分50秒 说: 127.0.0.1也不行? xieyunchao 2009年03月07日 11点43分17秒 说: 不行。刚试过。 xieyunchao 2009年03月07日 11点43分39秒 说: 我这个问题我郁闷老长时间了。就是不知道为什么! vc555 2009年03月07日 11点44分13秒 说: tnsping 127.0.0.1 xieyunchao 2009年03月07日 11点45分02秒 说: C:\Documents and Settings\Administrator>tnsping 127.0.0.1 TNS Ping Utility for 32-bit Windows: Version 9.2.0.1.0 - Production on 07-3月 -2 009 11:44:31 Copyright (c) 1997 Oracle Corporation. All rights reserved. 已使用的参数文件: D:\oracle9cli\network\admin\sqlnet.ora 已使用 HOSTNAME 适配器来解析别名 Attempting to contact (DESCRIPTION=(CONNECT_DATA=(SID=*)(SERVICE_NAME=127.0.0.1) )(ADDRESS=(PROTOCOL=TCP)(HOST=127.0.0.1)(PORT=1521))) TNS-12541: TNS:无监听器 C:\Documents and Settings\Administrator> vc555 2009年03月07日 11点45分40秒 说: 看了下,是你监听文件的问题。 vc555 2009年03月07日 11点45分52秒 说: LISTENER = (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.0.95)(PORT = 1521)) ) vc555 2009年03月07日 11点46分07秒 说: 别用IP,改成机器名。 vc555 2009年03月07日 11点46分33秒 说: 改了后,重启监听。 xieyunchao 2009年03月07日 11点46分57秒 说: 哦。知道了。谢谢。为什么要用机器名啊。ip有什么弊端啊。 vc555 2009年03月07日 11点49分10秒 说: 一个弊端就是你所遇到的问题。 还有个弊端就是如果监听用IP,假设你机器改了IP,那么不得不去改监听配置,而用机器名就无此问题 xieyunchao 2009年03月07日 11点49分45秒 说: 哦。豁然开朗,谢谢你啊。我都习惯用ip了,比较好记。谢谢。 通过ip得到机器名: tracert ip |
|