设为首页 收藏本站
查看: 676|回复: 0

[经验分享] Oracle listener静态注册和动态注册研究

[复制链接]

尚未签到

发表于 2016-8-4 13:31:30 | 显示全部楼层 |阅读模式
  Oracle listener静态注册和动态注册
一、什么是注册?
       注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。
       在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务,无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。
  二、静态注册
       静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。
       静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。
       采取静态注册方法时,$ORACLE_HOME/network/admin/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进程才会在很短的时间之内完成动态注册。
  四、查询某服务是静态注册还是动态注册
       可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。
       实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。
       动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管何时关闭数据库,动态注册的数据库都会动态地从监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的回退(fallback)和负载平衡。
  
操作实列例
  system :WSXP
oracle version:10.2.1
oracle instance_name: huiches;orcl;
默认数据库状态:huiches:关闭;orcl 关闭
默认linstener状态:关闭
系统设置oracle_sid为orcl
  一、静态注册
  即在listener 中注册所要监听的数据库实列
  如:
    SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (GLOBAL_DBNAME = huiches.com)
      (ORACLE_HOME = D:\oracle\product\10.1.0\db_1)
      (SID_NAME = HUICHES)
    )
  )
  1 、打开listener(先打开linstener,后打开数据库实例的操作):
  1.1.1 、listeren打开时的日志为 :
  TNSLSNR for 32-bit Windows: Version 10.1.0.2.0 - Production on 17-10月-2009 21:06:50
  Copyright (c) 1991, 2004, Oracle.  All rights reserved.
  系统参数文件为D:\oracle\product\10.1.0\db_1\network\admin\listener.ora
写入D:\oracle\product\10.1.0\db_1\network\log\listener.log的日志信息
写入D:\oracle\product\10.1.0\db_1\network\trace\listener.trc的跟踪信息
跟踪级别当前为0
  以 pid=512 开始
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=1521)))
  TIMESTAMP * CONNECT DATA [* PROTOCOL INFO] * EVENT [* SID] * RETURN CODE
  1.1.2 、检查linstener状态:
  服务摘要..
服务 "huiches.com" 包含 1 个例程。
  例程 "HUICHES", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
命令执行成功
  1.2 、在sqlplus中连接huiches数据库
  1.2.1 、打开记录为:
  SQL> conn /@huiches as sysdba;
Connected to an idle instance.
SQL> startup;
ORACLE instance started.
  Total System Global Area  142606336 bytes
Fixed Size                   787848 bytes
Variable Size             116128376 bytes
Database Buffers           25165824 bytes
Redo Buffers                 524288 bytes
数据库装载完毕。
数据库已经打开。
SQL>
  1.2.2 、 其listener连接日志为:
  17-10月-2009 21:10:05 * (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=huiches.com)(CID=(PROGRAM=D:\oracle\product\10.1.0\db_1\bin\sqlplusw.exe)(HOST=LIBIN)(USER=libin))) * (ADDRESS=(PROTOCOL=tcp)(HOST=192.168.3.196)(PORT=2833)) * establish * huiches.com * 0
17-10月-2009 21:10:21 * service_register * huiches * 0
17-10月-2009 21:10:21 * (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=huiches.com)(CID=(PROGRAM=D:\oracle\product\10.1.0\db_1\bin\sqlplusw.exe)(HOST=LIBIN)(USER=libin))) * (ADDRESS=(PROTOCOL=tcp)(HOST=192.168.3.196)(PORT=2840)) * establish * huiches.com * 0
17-10月-2009 21:10:25 * (CONNECT_DATA=(SERVER=DEDICATED)(SERVICE_NAME=huiches.com)(CID=(PROGRAM=D:\oracle\product\10.1.0\db_1\bin\sqlplusw.exe)(HOST=LIBIN)(USER=libin))) * (ADDRESS=(PROTOCOL=tcp)(HOST=192.168.3.196)(PORT=2843)) * establish * huiches.com * 0
17-10月-2009 21:10:27 * service_update * huiches * 0
17-10月-2009 21:10:43 * service_update * huiches * 0
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=8080))(Presentation=HTTP)(Session=RAW))
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=2100))(Presentation=FTP)(Session=RAW))
17-10月-2009 21:10:52 * service_update * huiches * 0
  1.2.3 、listener 状态为:
  服务摘要..
服务 "huiches.com" 包含 2 个例程。
  例程 "HUICHES", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
  例程 "huiches", 状态 READY, 包含此服务的 1 个处理程序...
服务 "huichesXDB.com" 包含 1 个例程。
  例程 "huiches", 状态 READY, 包含此服务的 1 个处理程序...
命令执行成功
  
2 打开instance(先打开数据库实例,后打开listener的操作):
  2.1.1 、打开数据库实例
  C:\Documents and Settings\libin>set oracle_sid=huiches
  C:\Documents and Settings\libin>sqlplus /nolog
  SQL*Plus: Release 10.1.0.2.0 - Production on 星期六 10月 17 21:46:22 2009
  Copyright (c) 1982, 2004, Oracle.  All rights reserved.
  SQL> conn / as sysdba;
已连接到空闲例程。
SQL> startup;
ORACLE 例程已经启动。
  Total System Global Area  142606336 bytes
Fixed Size                   787848 bytes
Variable Size             116128376 bytes
Database Buffers           25165824 bytes
Redo Buffers                 524288 bytes
数据库装载完毕。
数据库已经打开。
SQL>
  2.2.2 、打开listener
  2.2.2.1 、listeren打开时的日志为 :
  
TNSLSNR for 32-bit Windows: Version 10.1.0.2.0 - Production on 17-10月-2009 21:51:18
  Copyright (c) 1991, 2004, Oracle.  All rights reserved.
  系统参数文件为D:\oracle\product\10.1.0\db_1\network\admin\listener.ora
写入D:\oracle\product\10.1.0\db_1\network\log\listener.log的日志信息
写入D:\oracle\product\10.1.0\db_1\network\trace\listener.trc的跟踪信息
跟踪级别当前为0
  以 pid=2224 开始
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=1521)))
  TIMESTAMP * CONNECT DATA [* PROTOCOL INFO] * EVENT [* SID] * RETURN CODE
17-10月-2009 21:51:18 * (CONNECT_DATA=(CID=(PROGRAM=)(HOST=)(USER=libin))(COMMAND=status)(ARGUMENTS=64)(SERVICE=LISTENER)(VERSION=168821248)) * status * 0
   
  2.2.2.2 、检查linstener状态及日志:
  服务摘要..
服务 "huiches.com" 包含 2 个例程。
  例程 "HUICHES", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
  例程 "huiches", 状态 READY, 包含此服务的 1 个处理程序...
服务 "huichesXDB.com" 包含 1 个例程。
  例程 "huiches", 状态 READY, 包含此服务的 1 个处理程序...
命令执行成功
  
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=8080))(Presentation=HTTP)(Session=RAW))
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=2100))(Presentation=FTP)(Session=RAW))
17-10月-2009 21:51:49 * service_register * huiches * 0
17-10月-2009 21:52:23 * (CONNECT_DATA=(CID=(PROGRAM=)(HOST=)(USER=libin))(COMMAND=status)(ARGUMENTS=64)(SERVICE=LISTENER)(VERSION=168821248)) * status * 0
  二 、动态注册模式
  条件:删掉listener配置文件,则为默认的动态配置
  1 、打开listener(先打开linstener,后打开数据库实例的操作):
  1.1.1 、listeren打开时的日志为 :
  TNSLSNR for 32-bit Windows: Version 10.1.0.2.0 - Production on 17-10月-2009 22:14:09
  Copyright (c) 1991, 2004, Oracle.  All rights reserved.
  写入D:\oracle\product\10.1.0\db_1\network\log\listener.log的日志信息
写入D:\oracle\product\10.1.0\db_1\network\trace\listener.trc的跟踪信息
跟踪级别当前为0
  以 pid=2416 开始
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=1521)))
  TIMESTAMP * CONNECT DATA [* PROTOCOL INFO] * EVENT [* SID] * RETURN CODE
17-10月-2009 22:14:11 * (CONNECT_DATA=(CID=(PROGRAM=)(HOST=)(USER=libin))(COMMAND=status)(ARGUMENTS=64)(SERVICE=LISTENER)(VERSION=168821248)) * status * 0
  
1.1.2 、检查linstener状态:
  监听端点概要...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=1521)))
监听程序不支持服务
命令执行成功
  1.2 、打开数据库实例
  1.2.1 、打开记录为:
  C:\Documents and Settings\libin>set oracle_sid=huiches
  C:\Documents and Settings\libin>sqlplus /nolog
  SQL*Plus: Release 10.1.0.2.0 - Production on 星期六 10月 17 22:17:05 2009
  Copyright (c) 1982, 2004, Oracle.  All rights reserved.
  SQL> conn / as sysdba;
已连接到空闲例程。
SQL> startup
ORACLE 例程已经启动。
  Total System Global Area  142606336 bytes
Fixed Size                   787848 bytes
Variable Size             116128376 bytes
Database Buffers           25165824 bytes
Redo Buffers                 524288 bytes
数据库装载完毕。
数据库已经打开。
SQL>
  1.2.2 、 其listener日志为:
  17-10月-2009 22:17:18 * service_register * huiches * 0
17-10月-2009 22:17:24 * service_update * huiches * 0
17-10月-2009 22:17:42 * service_update * huiches * 0
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=8080))(Presentation=HTTP)(Session=RAW))
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=2100))(Presentation=FTP)(Session=RAW))
17-10月-2009 22:17:48 * service_update * huiches * 0
  1.2.3 、listener 状态为:
  服务摘要..
服务 "huiches.com" 包含 1 个例程。
  例程 "huiches", 状态 READY, 包含此服务的 1 个处理程序...
服务 "huichesXDB.com" 包含 1 个例程。
  例程 "huiches", 状态 READY, 包含此服务的 1 个处理程序...
命令执行成功
  
2 打开instance(先打开数据库实例,后打开listener的操作):
  2.1.1 、打开数据库实例
  C:\Documents and Settings\libin>set oracle_sid=huiches
  C:\Documents and Settings\libin>sqlplus /nolog
  SQL*Plus: Release 10.1.0.2.0 - Production on 星期六 10月 17 22:21:01 2009
  Copyright (c) 1982, 2004, Oracle.  All rights reserved.
  SQL> conn / as sysdba;
已连接。
SQL> shutdown
数据库已经关闭。
已经卸载数据库。
ORACLE 例程已经关闭。
SQL> startup
ORACLE 例程已经启动。
  Total System Global Area  142606336 bytes
Fixed Size                   787848 bytes
Variable Size             116128376 bytes
Database Buffers           25165824 bytes
Redo Buffers                 524288 bytes
数据库装载完毕。
数据库已经打开。
SQL>
  关闭打开huiches实例的DOS窗口,使oracle_sid=huiches局部变量无效
  打开orcl数据库实例
  SQL> conn / as sysdba;
已连接到空闲例程。
SQL> startup;
ORACLE 例程已经启动。
  Total System Global Area  100663296 bytes
Fixed Size                   787648 bytes
Variable Size              74185536 bytes
Database Buffers           25165824 bytes
Redo Buffers                 524288 bytes
数据库装载完毕。
数据库已经打开。
SQL>
  
2.2.2 、打开listener
  2.2.2.1 、listeren打开时的日志为 :
  TNSLSNR for 32-bit Windows: Version 10.1.0.2.0 - Production on 17-10月-2009 23:19:57
  Copyright (c) 1991, 2004, Oracle.  All rights reserved.
  写入D:\oracle\product\10.1.0\db_1\network\log\listener.log的日志信息
写入D:\oracle\product\10.1.0\db_1\network\trace\listener.trc的跟踪信息
跟踪级别当前为0
  以 pid=3700 开始
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=1521)))
  TIMESTAMP * CONNECT DATA [* PROTOCOL INFO] * EVENT [* SID] * RETURN CODE
17-10月-2009 23:19:57 * (CONNECT_DATA=(CID=(PROGRAM=)(HOST=)(USER=libin))(COMMAND=status)(ARGUMENTS=64)(SERVICE=LISTENER)(VERSION=168821248)) * status * 0
  监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=8080))(Presentation=HTTP)(Session=RAW))
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=2100))(Presentation=FTP)(Session=RAW))
17-10月-2009 23:18:16 * service_register * orcl * 0
  
2.2.2.2 、检查linstener状态及日志:
  监听端点概要...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=1521)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=8080))(Presentation=HTTP
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=LIBIN)(PORT=2100))(Presentation=FTP)
服务摘要..
服务 "orcl.com" 包含 1 个例程。
  例程 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
服务 "orclXDB.com" 包含 1 个例程。
  例程 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
命令执行成功
  说明:在静态模式或动态模式下,先打开listener后打开数据库实例的情况下,listener会动态的注册数据库实例,并监听其数据库状态变化(service_register、service_update、service_died);在先打开数据库实例,后打开listener的情况下,listener会动态的注册oracle_sid有效的数据库实例,无论是设置为局部或全局oracle_sid;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-252794-1-1.html 上篇帖子: Oracle中BLOB和CLOB字段的操作 下篇帖子: oracle 左右连接与mysql左右连接区别
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表