与虚拟机Oracle连接出现ora-12154问题的解决方法
程序员文章站
2022-09-06 14:35:05
谈到ora-12154问题,网上有一大堆解决方法,原因基本统一:tns或listener配置不正确。对于listener配置不正确的一般较少发生,大多数人都是按照默认配置一...
谈到ora-12154问题,网上有一大堆解决方法,原因基本统一:tns或listener配置不正确。对于listener配置不正确的一般较少发生,大多数人都是按照默认配置一路“下一步”过来的,基本都是orcl的服务名,如果说本地可以连通orcl,别的机子就连不通那应该跟listener关系不大。大部分都是tns配置不正确。我遇到的现象是:在本机建了一个2003的虚拟机,虚拟机里面装了oracle10g,默认配置。本机只装了oracle10g的客户端,当我以前用本机连接局域网内数据库的orcl服务(数据库与局域网内数据库一样)时没有问题,但是在连接虚拟机中的orcl服务却连不通,总是报ora-12154错误。而虚拟机内,plsql却可以连接虚拟机oracle,但是不能连接本机所在局域网内的oracle。
按照如下过程,一般都能解决:
- 在虚拟机内开cmd,用lsnrctl status查看监听器监听的服务
- 如看到监听服务“orcl”,那在本机的tns配置中(service_name = orcl)必须写orcl;如果想要自定义,则在虚拟机内的listener配置中就要加入自定义服务名,记得要重启监听服务:lsnrctl reload
- 最后形成的配置文件如下
虚拟机listener:
sid_list_listener = (sid_list = (sid_desc = (global_dbname = test) 自定义服务名 (oracle_home = e:\oracle\product\10.2.0\db_1) db_home (sid_name = test) ) (sid_desc = (program = extproc) (sid_name = plsextproc) (oracle_home = e:\oracle\product\10.2.0\db_1) ##这个服务保证你可以使用外部过程,如c程序 ) )
本机tns:
orcl_xnj = (description = (address_list = (address = (protocol = tcp)(host = 182.12.15.232)(port = 1521)) ) (connect_data = (service_name = test) 与自定义服务名对应 ) )
再次连接,问题解决!
记住,一定从最简单的原因找起,不要一上去就看到网上的什么改process数、注册表之类的,要想想本机能连为什么通过网络就不行,还是定位问题。
推荐阅读
-
Hive与Oracle之间利用Sqoop进行数据的导入导出时遇到的问题及解决方法
-
win7系统连接远程桌面出现闪退问题的两种解决方法详细教程
-
linux系统oracle数据库出现ora12505问题的解决方法
-
Oracle连接出现ora-12154无法解析指定的连接标识符
-
Oracle导dmp出现文件ORA-12154: TNS: 无法解析指定的连接标识符问题的解决方案
-
与虚拟机Oracle连接出现ora-12154问题的解决方法
-
关于Oracle本地连接出现与监听有关的问题的解决方法探讨
-
如何解决Filezilla 与虚拟机连接不上的问题
-
Linux连接windows的ftp unzip出现问题的解决方法
-
苹果Mac无法连接wifi怎么办 苹果Mac出现wifi连接问题的解决方法