ORA-12154 连接串引起的闹心的小问题总结

2 篇文章 0 订阅
1 篇文章 0 订阅

一、问题

    某个应用系统需要从L服务器连接到Oracle数据库R上采集数据,我将连接串添加至$ORACLE_HOME/network/admin/tnsnames.ora文件中,但是发现应用连接不到数据库。这时我使用sqlplus连接数据库,发现报错ORA-12154:无法解析指定的连接标识符,又用tnsping 连接串名,发现报错TNS-03505: Failed to resolve name。此时就怀疑是连接串写法有误,通过各种比对,又在网上找解决方案一直无法解决。后来师傅将这个问题解决了,而且这个问题是网上没有找到过的,因此在这里将问题和解决方案与大家分享下。

二、思路和解决方案

1. 发现应用连接不到数据库后,先在L服务器上使用sqlplus登录数据库。

# su - oracle
$ sqlplus /nolog

SQL> conn system/password@x86_rcount_1523_P4

输入登录命令后,报错ORA-12154:无法解析指定的连接标识符。此时可以确定问题是在连接串的写法上。

2.tnsping R服务器的vip,是通的。基本可以确定网络没有问题。

3.我又使用自己的电脑,将连接串添加至$ORACLE_HOME/network/admin/tnsnames.ora,再通过sqlplus居然能够登录!

此时可以确定:R服务器的监听没有问题、L至R的网络没有问题、连接串本身没有问题。那问题出在了哪里?


根据本次问题和之前的问题,我总结成3点。

1.连接串从windows系统拷贝至Linux/UNIX系统时,引入了不可见的空格、tab符等。连接串本身是对格式、缩进有要求的,因此可能导致连接串不可用。此问题不常见,也很好解决。

2.密码中含有了@字样。

例如:conn  system/pwd@123@x86_rcount_1523_P4

第一个@是密码中的字符,第二个@是表示连接串名。如果这么写的话,程序会误认为第一个@后的是连接串名,导致无法正确连接远端数据库。解决办法一是避免密码中使用@;二是转义,可以用这种方法登录:conn  system/\"pwd@123\"@x86_rcount_1523,P4 使用\"  \"将密码包含进去避免程序解析出现错误。

这种问题也比较常见,值得注意!

3.上一个连接串的缩进格式错误!这个问题也是我这次遇到的。我将之前所有遇到的问题都排查了一遍,也没有发现有什么问题。

后来得知,是我这个连接串的上一个连接串就出现了问题1,而且那个连接串也没有应用使用,因此它的问题就一直在那里没有人处理。但是上一个连接串出现这个问题会影响到我这个连接串,将上一个连接串格式改好后,马上就可以使用了!





  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值