为了正常的体验网站,请在浏览器设置里面开启Javascript功能!

ORACLE客户端监听配置错误

2012-12-19 7页 doc 243KB 32阅读

用户头像

is_914635

暂无简介

举报
ORACLE客户端监听配置错误 问题现象: 在本地ORACLE客户端下配置26数据库本地服务名时配置正常,连接正常。 同样操作用于配置150数据库本地服务名时,用PL/SQL连接报错 解决办法: 定位问题初期,张媚茜可以通过本地服务名访问到150数据库,我这边不可以。 决定首先保持环境一致,即服务端都是150数据库(相同),客户端均采用同一个安装文件安装(保持相同) 通过对比张媚茜机器上oracle客户端中tnsmanes.ora与我本地机器文件 发现出现orcl的位置,我的本地文件中参数名SERVICE_NAME,张媚茜的文件中参数名SI...
ORACLE客户端监听配置错误
问题现象: 在本地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也可以解决此问题,并且客户端可以按照标准要求配置。 参考资料: 一、什么是注册?   注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名DB_NAME和实例名SID,只需要知道该数据库对外提供的服务名SERVICE_NAME就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。 (即本地Net Configuration Assistant => 本地Net服务名配置时,所添加的服务名) 在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。) 26服务器上DB_NAME和SERVICE_NAME和SID保持一致,都是orcl 150服务器上DB_NAME和SERVICE_NAME一致,是oracle,但是SID是orcl 相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。 疑问: 1、为什么一个数据库可以有多个实例?有什么好处? 数据库名与实例名之间的关系一般是一一对应关系,有一个数据库名就有一个实例名,如果在一个服务器中创建两个数据库,则有两个数据库名,两个数据库实例名,用两个标识确定一个数据库,用户和实例相连接。 但在8i、9i的并行服务器结构中,数据库与实例之间不存在一一对应关系,而是一对多关系,(一个数据库对应多个实例,同一时间内用户只一个实例相联系,当某一实例出现故障,其它实例自动服务,以保证数据库安全运行。) 2、为什么一个数据库可以有多个服务名?有什么好处? 打个比方,你的名字叫小明,但是你有很多外号。你父母叫你小明,但是朋友都叫你的外号。 这里你的父母就是oracle实例,小明就是sid,service name就是你的外号 3、动态注册静态注册的主要区别是什么?有什么好处? 二、静态注册   静态注册就是实例启动时读取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中。   首先要在init.ora中指定instance_name,service_names两个参数的值。在sqlplus下通过show parameter service_names 和show parameter instance_name可以查看这两个参数的值。   注册到监听器中的实例值从init.ora文件中的instance_name参数取得。如果该参数没有设定值,那么它将取init.ora文件中的db_name的值。   注册到监听器中的服务值从init.ora文件中的参数service_names取得。如果该参数没有设定值,数据库将拼接init.ora文件中的 db_name和db_domain的值来注册自己。如果选择提供service_names值,您可以使用完全限定的名称(比如 orcl.oracle.com)或缩写的名称(比如orcl)。如果选择缩写的名称并设置了db_domain参数,注册到监听器中的服务将是 service_name值和db_domain值的拼接。例如下面的设置将导致服务orcl.oracle.com被注册到监听器中: db_domain=oracle.com service_names=orcl ;   采取动态注册方法时,listener.ora中的内容如下: SID_LIST_LISTENER = (SID_LIST = (SID_DESC = (SID_NAME = PLSExtProc) (ORACLE_HOME = D:\oracle\product\10.2.0\db_1) (PROGRAM = extproc) ) )   可选择的是,您可以在service_names参数中指定多个服务值,值之间用逗号格开,这对于共享服务器配置是很有用的。   动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、是TCP),如果需要向非默认监听注册,则需要配置local_listener参数!   如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种情况 下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最好在所有的数据库启动之前先启动监听器,这样就会避免没有显式设置 service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的情况。   为初始化参数service_names和instance_name设置显式的值是个值得可取的方法和建议。因为如果监听器在数据库运行过程中要重新启 动,仅当你在init.ora文件中显式地设置了service_names和instance_name的值时,每个数据库的PMON进程才会在很短的 时间之内完成动态注册。 4、怎么查看静态注册还是动态注册? 可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。   实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。   动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册的数据库都会动态地从 监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的回退 (fallback)和负载平衡。 关键字: DB_NAME, 数据库名, 随着由多个数据库构成的分布式数据库的普及,这种命令数据库的方法给数据库的管理造成一定的负担,因为各个数据库的名字可能一样,造成管理上的混乱。为了解决这种情况,引入了Db_domain参数,这样在数据库的标识是由Db_name和Db_domain两个参数共同决定的,避免了因为数据库重名而造成管理上的混乱。这类似于互连网上的机器名的管理。我们将Db_name和Db_domain两个参数用’.’连接起来,表示一个数据库 DB_DOMAIN, 定义数据库所在的域 该域的命名同互联网的’域’没有任何关系,只是数据库管理员为了更好的管理分布式数据库而根据实际情况决定的。当然为了管理方便,可以将其等于互联网的域。 GLOBLE_NAME, 对一个数据库的唯一标识,默认是DB_NAME.DBDOMAIN(监听器识别globle_name) oracle建议用此种方法命令数据库。该值是在创建数据库是决定的 SERVICE_NAME, 数据库服务名,ORACLE8i引入,默认是DB_NAME.DBDOMAIN (客户端识别service_name) 该参数是oracle8i新引进的。在8i以前,我们用SID来表示标识数据库的一个实例,但是在Oracle的并行环境中,一个数据库对应多个实例,这样就需要多个网络服务名,设置繁琐。为了方便并行环境中的设置,引进了Service_name参数,该参数对应一个数据库,而不是一个实例,而且该参数有许多其它的好处。该参数的缺省值为Db_name. Db_domain,即等于Global_name。一个数据库可以对应多个Service_name,以便实现更灵活的配置。该参数与SID没有直接关系,即不必Service name 必须与SID一样。 INSTANCE_NAME, 数据库实例名(数据库参数oracle识别) 数据库实例名。用于和操作系统之间的联系,用于对外部连接时使用。在操作系统中要取得与数据库之间的交互,必须使用数据库实例名 ORACLE_SID 数据库实例名(操作系统环境变量linux识别) 操作系统环境变量
/
本文档为【ORACLE客户端监听配置错误】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。 本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。 网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。

历史搜索

    清空历史搜索