ORACLE客户端监听配置错误.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
问题现象: 在本地ORACLE客户端下配置26数据库本地服务名时配置正常,连接正常。 同样操作用于配置150数据库本地服务名时,用PL/SQL连接报错 解决办法: 定位问题初期,张媚茜可以通过本地服务名访问到150数据库,我这边不可以。 决定首先保持环境一致,即服务端都是150数据库(相同),客户端均采用同一个安装文件安装(保持相同) 通过对比张媚茜机器上oracle客户端中tnsmanes.ora与我本地机器文件 发现出现orcl的位置,我的本地文件中参数名SERVICE_NAME,张媚茜的文件中参数名SID_NAME 更改我的参数名为SID_NAME或SID时,问题解决,可以成功连接。 问题分析: Oracle配置连接流程 客户端==》监听器==》服务端 服务端的数据库对外提供service_name供客户端连接 所以客户端需要配置服务端提供的service_name, 服务端启动的时候会在监听器上注册两个参数,SID和SERVICE_NAME SID提供给JDBC连接,SERVICE_NAME提供给客户端连接 ORACLE8i之后oracle引入service_name参数就是专门用来提供给客户端连接 Oracle服务端在监听器上注册时读取%ORACLE_HOME%//product/10.2.0/network/admin/ listener.ora文件 其中GLOBAL_DBNAME就是注册在监听器上的对外网连接名称。 SID_NAME就是注册在监听器上的实例名。 所以通过修改此文件中的GLOBLE_DBNAME也可以解决此问题,并且客户端可以按照标准要求配置。 参考资料: 一、什么是注册?   注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。数据库名与实例名之间的关系一般是一一对应关系,有一个数据库名就有一个实例名,如果在一个服务器中创建两个数据库,则有两个数据库名,两个数据库实例名,用两个标识确定一个数据库,用户和实例相连接。 但在8i、9i的并行服务器结构中,数据库与实例之间不存在一一对应关系,而是一对多关系,(一个数据库对应多个实例,同一时间内用户只一个实例相联系,当某一实例出现故障,其它实例自动服务,以保证数据库安全运行。) 打个比方,你的名字叫小明,但是你有很多外号。你父母叫你小明,但是朋友都叫你的外号。 这里你的父母就是oracle实例,小明就是sid,service name就是你的外号 二、静态注册   静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。   静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。   采取静态注册方法时,listener.ora中的内容如下: SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = PLSExtProc) (ORACLE_HOME = D:\oracle\product\10.2.0\db_1) (PROGRAM = extproc) ) (SID_DESC = (GLOBAL_DBNAME =orcl) (ORACLE_HOME = D:\oracle\product\10.2.0\db_1) (SID_NAME =orcl) ) (SID_DESC = (GLOBAL_DBNAME =orcl1) (ORACLE_HOME = D:\oracle\product\10.2.0\db_1) (SID_NAME =orcl) ) 该文件表明数据库是单实例的,实例名为orcl,向外提供了两个服务:orcl和orcl1 三、动态注册   动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,service_names两个参数将实例和服务动态注册到listener中。   首先

文档评论(0)

80092355km + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档