连接oracle数据库报“ORA-12154: TNS: 无法解析指定的连接标识符”错误,怎么解决

连接oracle数据库报“ORA-12154: TNS: 无法解析指定的连接标识符”错误,怎么解决,第1张

你确定你的库里面service_names参数也配置了STUDENT?没有配的话是不行的,

SERVICE_NAME = student

没有配的话这个库不认识,你还改成SERVICE_NAME = orcl试试,最开始的STUDENT名称可以不用改

ora-16020的错误是因为你的归档路径设置少于参数LOG_ARCHIVE_MIN_SUCCEED_DEST的值;

首先,检查该参数的设置。

使用sys用户登录,

$ sqlplus "/ as sysdba"

sql> show parameter LOG_ARCHIVE_MIN_SUCCEED_DEST;

如果该值大于1 ,则需要检查归档目的参数

sql> show parameter log_archive_dest

但,默认的参数设置是1,如果参数LOG_ARCHIVE_MIN_SUCCEED_DEST的值为1,这时情况较为简单。

登录数据库使用archive log list,或者上面的show parameter参数检查归档目的地;并确认归档路径文件夹存在,并且oracle用户对其有write权限即可。

SQL> archive log list;

# chown oracle:dba /dest

ORA-12154: TNS: 无法解析指定的连接标识符 问题\x0d\\x0d\相信作为ORACLE数据库的开发人员没有少碰到“ORA-12154: TNS: 无法解析指定的连接标识符”,今天我也又碰到了类似的情况,将我的解决方法进行小结,希望能对碰到同样问题的友人们提供帮助。\x0d\\x0d\问题场景描述:\x0d\\x0d\服务器端版本:oracle 102010\x0d\\x0d\客户端版本:oracle 102010\x0d\\x0d\客户端开发工具:PL/SQL Developer\x0d\\x0d\通过客户端来连接服务器,其主要文件就是通过客户端的tnsnamesora来配置,在原文件的基础上增加:\x0d\\x0d\SID别名 =\x0d\ (DESCRIPTION =\x0d\ (ADDRESS_LIST =\x0d\ (ADDRESS = (PROTOCOL = TCP)(HOST = SERVER_IP)(PORT = 1521))\x0d\ )\x0d\ (CONNECT_DATA =\x0d\ (SID = SID_NAME)\x0d\ )\x0d\ )\x0d\\x0d\例:\x0d\\x0d\dev_db =\x0d\ (DESCRIPTION =\x0d\ (ADDRESS_LIST =\x0d\ (ADDRESS = (PROTOCOL = TCP)(HOST = 172168105)(PORT = 1521))\x0d\ )\x0d\ (CONNECT_DATA =\x0d\ (SID = ora10)\x0d\ )\x0d\ )\x0d\\x0d\通过PL/SQL Developer连接dev_db时,报“ORA-12154: TNS: 无法解析指定的连接标识符”。(这个问题以前也碰到过,但解决方法不太一样,因具体的问题不太一样。)\x0d\\x0d\我将自己知道的一些解决方法说一下:\x0d\\x0d\1先检查服务器端的监听服务是否打开,如果没有打开请启动其监听\x0d\\x0d\ 客户端:tnsping \x0d\ 服务器Linux下:\x0d\\x0d\ #>lsnrctl status 查看监听状态\x0d\\x0d\ #>lsnrctl start 启动监听\x0d\\x0d\2通过Sql Plus连接一下试试,如果Sql Plus连接能成功,那就说明你的tnsnamesora内容有错误\x0d\\x0d\我的问题就在别名dev_db前面有一个空格,这个可以通过文本编辑器(Edit Plus,UE等)来查看是否有空格,只要有空格那就肯定是不行的,而且如果那段内容是出现在文件的中间的话,将导致该文件里所有相应的连接别名都不成功,如果是在最后面就只有其自身连接别名不能成功,其他连接别名还是能连接成功。(注:我的tnsnamesora配置了多个数据库实例的连接,所有才有多个连接别名。)\x0d\\x0d\如:\x0d\\x0d\空格dev_db =\x0d\ (DESCRIPTION =\x0d\ (ADDRESS_LIST =\x0d\ (ADDRESS = (PROTOCOL = TCP)(HOST = 172168105)(PORT = 1521))\x0d\ )\x0d\ (CONNECT_DATA =\x0d\ (SID = ora10)\x0d\ )\x0d\ )\x0d\\x0d\3如果确保你的tnsnamesora内容没有错误,那请将%ORACLE_HOME%\product\1020\db_1\NETWORK\ADMIN目录下的所有文件删了,然后重新连接,一般就能解决了。\x0d\\x0d\说明一下:那个目录里的文件是在你建立连接的时候动态生成的,不要怕删了会有问题\x0d\\x0d\4进入PLSQL Developer的主界面,在登录界面选择取消即不登录进入主界面,然后选择菜单Tools(工具)-Preferences(首选项),在设置窗口中,选择Oracle-Connection(连接),对应设置窗口中,找到Oracle Home(Oracle主目录),选择你本地所安装客户端的版本,保存设置,然后重新启动PLSQL Developer,这时就可以正常登录了。

1检查注册表,HKey_LocalMachineSoftwareOracle下面的Oracle_Home,若不对,修改成正确的;

2卸载ODP for Net (或者卸载ODT for Net, ODT中包含ODP, ODT 是VSNet的一个集成插件,用于连接和浏览oracle数据库,并且提供对oracle数据库的拖拽 *** 作,类似VSNet对于SQL Server的资源管理器);

3如果ODT for Net的目录依然存在,删除或者重命名此目录;

然后重起系统,重新连接ASPNet程序,如果还有同样的错误,看着办吧,我建议重装Oracle吧。

分析原因:系统原来装的是ORACLE 10G 1010,卸载后还没重启就装上1020,结果先是监听器起不来,竟然还是指向1010的位置,监听器当然不能启动了。

处理过程:

1、查找注册表,将监听器指向新的位置,重启服务,OK;

2、PL/SQL DEVELOPER还是连接不了,其它方式都正常。将原先安装在其它逻辑盘的ODP for Net 卸载重装到与ORACLE 1020同一位置。重启系统,DEVELOPER还是报错,不过些时报错提示信息为空。

3、因为DEVELOPER设置有更改后,进入菜单TOOLS》PREFERENCES设置,在ORACLE下的CONNECTION中,将ORACLE HOME和OCI LIBIARY设为空即自动检测。连接正常,问题解决。

二、应用程序中报错:

一个很难想到的引起ORA-12154的原因

使用OracleClientOracleConnection时(我连的是Oracle 9i,其他版本未知),如果你的执行目录太长或者有括号等(未考察有些什么符号),那么即使你的服务名是对的,也会引起ORA-12154问题“TNS: 无法处理服务名”,当出现这个问题时,请也考虑这个原因。

B.进行适当的配置

如何正确配置tnsnameora文件:

可以在客户端机器上使用oracle Net Configuration Assistant或oracle Net Manager图形配置工具对客户端进行配置,该配置工具实际上修改tnsnamesora文件。所以我们可以直接修改tnsnamesora文件,下面以直接修改tnsnamesora文件为例:

该文件的位置为: …networkadmintnsnamesora (for windows)

…/network/admin/tnsnamesora (for unix)

此处,假设服务器名为testserver,服务名为orcltestservercom,使用的侦听端口为1521,则tnsnamsora文件中的一个test网络服务名(数据库别名)为:

test =

(DESCRIPTION=

(ADDRESS_LIST=

(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521))

)

(CONNECT_DATA=(SERVICE_NAME=orcltestservercom)

)

)

此处的笑脸为)。

红色的内容为需要根据实际情况修改的内容,现解释如下:

PROTOCOL:客户端与服务器端通讯的协议,一般为TCP,该内容一般不用改。

HOST:数据库侦听所在的机器的机器名或IP地址,数据库侦听一般与数据库在同一个机器上,所以当我说数据库侦听所在的机器一般也是指数据库所在的机 器。在UNIX或WINDOWS下,可以通过在数据库侦听所在的机器的命令提示符下使用hostname命令得到机器名,或通过ipconfig(for WINDOWS) or ifconfig(for UNIX)命令得到IP地址。需要注意的是,不管用机器名或IP地址,在客户端一定要用ping命令ping通数据库侦听所在的机器的机器名,否则需要在 hosts文件中加入数据库侦听所在的机器的机器名的解析。

PORT:数据库侦听正在侦听的端口,可以察看服务器端的listenerora文件或在数据库侦听所在的机器的命令提示符下通过lnsrctl status [listener name]命令察看。此处Port的值一定要与数据库侦听正在侦听的端口一样。

SERVICE_NAME:在服务器端,用system用户登陆后,sqlplus> show parameter service_name命令察看。

如何利用配置的网络服务名连接到数据库:

用sqlplus程序通过test网络服务名进行测试,如sqlplus system/manager@test。如果不能连接到数据库,则在tnsnameora文件中的test网络服务名(net service)后面加上sqlnetora文件中NAMESDEFAULT_DOMAIN参数的值,此处我的参数值为testservercom,将其加到网络服务名后面,修改后的tnsnameora中关于该网络服务名的内容为:

什么情况下会引起oracle自动设置NAMESDEFAULT_DOMAIN参数?

出现这种情况的典型环境为windows的客户端的‘我得电脑à属性à计算机名à更改à其它…à此计算机的主DNS后缀’中设置了‘primary dns suffix’,因为在这种情况下安装客户端时,会在sqlnetora文件中自动设置NAMESDEFAULT_DOMAIN参数,或许当把计算机加入域中安装oracle客户端时也会出现这种情况,有条件的话大家可以试一下。

我在设置oracle的客户端时一般手工修改tnsnamesora文件,但是还有许多人喜欢用图形工具配置,该图形工具最终还是修改tnsnamesora文件,但是它有时会引起其它的问题:

在用oracle的图形配置软件'net assistant'或‘Net Configuration Assistant’配置网络服务名时,假如已经设置了‘primary dns suffix’,但是在图形配置软件中写的网络服务名的名字中没有‘primary dns suffix’,如只是写了test,则图形配置软件会自动在后面加上‘primary dns suffix’,使之变为testtestservercom,并存在tnsnamesora中,而不管你的sqlnetora文件中是否有 NAMESDEFAULT_DOMAIN参数。此时,用图形工具进行测试连接是通过的,但是假如此时sqlnetora文件中没有 NAMESDEFAULT_DOMAIN参数,则你在使用网络服务名时应该使用在tnsnamesora中的 testtestservercom,而不是你在图形配置软件中键入的test。解决的办法为:

<1>可以在sqlnetora文件中设置NAMESDEFAULT_DOMAIN= testservercom,这时你可以用test或testtestservercom连接数据库

<2>在sqlnetora文件中不设置NAMESDEFAULT_DOMAIN参数,在tnsnamesora文件中将testtestservercom中的testservercom去掉,这时你可以用test连接数据库。

关于为什们在网络服务名后面加db_domain参数,需要了解sqlplus连接数据库的原理,我在后面解决12154常见故障中给出了详细的说明。

如果上面的招数还不奏效的话,只好用一下乾坤大挪移了。

将客户端的网络服务名部分

testtestservercom =

(DESCRIPTION=

(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521))

)

(CONNECT_DATA=(SERVICE_NAME=orcltestservercom)

)

)

此处的笑脸为)。

拷贝到服务器的tnsnamesora文件中。然后再服务器端用sqlplus system/manager@testtestservercom连接到数据库。

如果能连接成功,说明你的客户端与服务器端的网络有问题。

如果连接不成功,用前面的部分检查网络服务名部分部分是否正确,如果确信网络服务名部分正确而且所有的客户端都连不上数据库则可能为系统TCP/IP或Oracle系统有问题,建议重新安装数据库。

常见故障解决办法:

TNS-12154 (ORA-12154):TNS:could not resolve service name

该错误表示用于连接的网络服务名在tnsnamesora文件中不存在,如上面的tnsnamesora中的网络服务名只有test,假如用户在连接时用sqlplus system/manager@test1则就会给出TNS-12154错误。

要注意的是,有时即使在tnsnamesora文件中有相应的网络服务名,可是用该网络服务名连接时还会出错,出现这种情况的典型配置如下(在客户端的机器上):

sqlnetora文件:

NAMESDIRECTORY_PATH = (TNSNAMES, …)

NAMESDEFAULT_DOMAIN = servercom

tnsnamesora文件:

test =

(DESCRIPTION=

(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=testserver)(PORT=1521))

)

(CONNECT_DATA=(SERVICE_NAME=orcltestservercom)

)

)

此处的笑脸为)。

sqlplus运行基本机理:

在用户输入sqlplus system/manager@test后,sqlplus程序会自动到sqlnetora文件中找NAMESDEFAULT_DOMAIN参数,假 如该参数存在,则将该参数中的值取出,加到网络服务名的后面,即此例中你的输入由sqlplus system/manager@test自动变为sqlplus system/manager@testservercom ,然后再到tnsnamesora文件中找testservercom网络服务名,这当然找不到了,因为该文件中只有test网络服务名,所以报 错。解决的办法就是将sqlnetora文件中的NAMESDEFAULT_DOMAIN参数注释掉即可,如 #NAMESDEFAULT_DOMAIN = servercom。假如NAMESDEFAULT_DOMAIN参数不存在,则sqlplus程序会直接到tnsnamesora文件中找 test网络服务名,然后取出其中的host,port,tcp,service_name,利用这些信息将连接请求发送到正确的数据库服务器上。

另外原则上tnsnamesora中的配置不区分大小写,但是我的确遇到区分大小写的情况,所以最好将使用的网络服务与tnsnamesora中配置的完全一样。

ORA-12514: TNS:listener could not resolve SERVICE_NAME given in connect Descriptor

该错误表示能在tnsnamesora中找到网络服务名,但是在tnsnamesora中指定的SERVICE_NAME与服务器端的SERVICE_NAME不一致。解决的办法是修改tnsnamesora中的SERVICE_NAME。

易混淆术语介绍:

Db_name:对一个数据库(Oracle database)的唯一标识,该数据库为第一章讲到的Oracle database。这种表示对于单个数据库是足够的,但是随着由多个数据库构成的分布式数据库的普及,这种命令数据库的方法给数据库的管理造成一定的负 担,因为各个数据库的名字可能一样,造成管理上的混乱。为了解决这种情况,引入了Db_domain参数,这样在数据库的标识是由Db_name和 Db_domain两个参数共同决定的,避免了因为数据库重名而造成管理上的混乱。这类似于互连网上的机器名的管理。我们将Db_name和 Db_domain两个参数用’’连接起来,表示一个数据库,并将该数据库的名称称为Global_name,即它扩展了Db_name。 Db_name参数只能由字母、数字、’_’、’#’、’$’组成,而且最多8个字符。

Db_domain:定义一个数据库所在的域,该域的命名同互联网的’域’没有任何关系,只是数据库管理员为了更好的管理分布式数据库而根据实际情况决定的。当然为了管理方便,可以将其等于互联网的域。

Global_name:对一个数据库(Oracle database)的唯一标识,oracle建议用此种方法命令数据库。该值是在创建数据库是决定的,缺省值为Db_name Db_domain。在以后对参数文件中Db_name与Db_domain参数的任何修改不影响Global_name的值,如果要修改Global_name,只能用ALTER DATABASE RENAME GLOBAL_NAME TO <db_namedb_domain>命令进行修改,然后修改相应参数。

Service_name:该参数是oracle8i新引进的。在8i以前,我们用SID来表示标识数据库的一个实例,但是在Oracle的并行环境中, 一个数据库对应多个实例,这样就需要多个网络服务名,设置繁琐。为了方便并行环境中的设置,引进了Service_name参数,该参数对应一个数据库, 而不是一个实例,而且该参数有许多其它的好处。该参数的缺省值为Db_name Db_domain,即等于Global_name。一个数据库可以对应多个Service_name,以便实现更灵活的配置。该参数与SID没有直接关 系,即不必Service name 必须与SID一样。

Net service name:网络服务名,又可以称为数据库别名(database alias)。是客户端程序访问数据库时所需要,屏蔽了客户端如何连接到服务器端的细节,实现了数据库的位置透明的特性。

看完本文后的感觉:

顶一下

踩一下 返回服务器首页文章内容投诉论坛收藏此页关闭客服投诉热线

以上就是关于连接oracle数据库报“ORA-12154: TNS: 无法解析指定的连接标识符”错误,怎么解决全部的内容,包括:连接oracle数据库报“ORA-12154: TNS: 无法解析指定的连接标识符”错误,怎么解决、oracle ORA-12154: TNS:could not resolve the connect identifier specified 错误、pl/sql developer 登陆时 出现"ORA-12154: TNS:无法解析指定的连接标等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zz/9837044.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存