oracle 监听动态注册,Oracle Listener静态配置、动态注册以及LOCAL_LISTENER问题 | 学步园...

动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、协议是

TCP),因为pmon只会动态注册port等于1521的监听。如果需要向非默认监听注册,则需要配置local_listener参数,并将监听的信 息添加到tnsnames.ora文件中(或者配置local_listener参数的值为LOCAL_LISTENER='(ADDRESS = (PROTOCOL = TCP)(HOST =xxx.xxx.xxx.xxx)(PORT = 1522)))。 注意,是tnsnames.ora 文件, 因为pmon在动态注册监听时要从tnsnames.ora中读取相关信息。  LISTENER

=(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = DaveDai)(PORT = 1522)))然后以sys用户运行(这里也可以直接修改init文件):SQL> alter system set local_listener=listener scope=both;SQL> alter system register;或者:SQL> alter system set LOCAL_LISTENER='(ADDRESS = (PROTOCOL = TCP)(HOST = xxx.xxx.xxx.xxx)(PORT = 1522))';1.1.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静态监听:oracle实例运行后,监听程序启动时,根据listener.ora的配置注册相应的服务。其中global_dbname对应的是oracle对外的服务名,即初始化参数里的service_names而sid_name对应的是oralce实例的名称,即初始化参数里的instance_name1.1.4           查询某服务是静态注册还是动态注册可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册的数据库都 会动态地从监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的

回退(fallback)和负载平衡。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值