`

listener静态注册和动态注册总结

阅读更多

一、什么是注册?
c?6zRc0
注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。ITPUB个人空间*iG1Oe+x
在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)
!@)Z}6O b0相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立客户端和服务器之间的连接。
%q'K(YIS3I `0二、静态注册
!o b;ei+X%aC0f0静态注册就是实例启动时读取listener.ora文件的配置,将实例和服务注册到监听程序。无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。ITPUB个人空间0_p-CC m2n|h
静态注册时,listener.ora中的GLOBAL_DBNAME向外提供服务名,listener.ora中的SID_NAME提供注册的实例名。
"H7\3[M Ndi/mF0采取静态注册方法时,listener.ora中的内容如下:
6v4~n&u)OR0SID_LIST_LISTENER =ITPUB个人空间4}*t'}3U'P$k#V
  (SID_LIST =
sLGQ*S;L[0    (SID_DESC =
y s_F!O u0       (SID_NAME = PLSExtProc)
8`*u}i9cc"S4I0       (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
"I'z'qc5xe0       (PROGRAM = extproc)
(u%V;A^#E&W0    )ITPUB个人空间XR9L!a8Z~0F
   (SID_DESC =
`!V,` V$?4X"XS0       (GLOBAL_DBNAME =orcl)
JR0WB {0c y&tR%CM0       (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
^@p$h~,G0       (SID_NAME =orcl)
(L-U P4o F0   )ITPUB个人空间*bg y cT8aH(Y"W
   (SID_DESC =ITPUB个人空间:^L:X @o
       (GLOBAL_DBNAME =orcl1)ITPUB个人空间E$b c9B*W0UP
       (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)ITPUB个人空间&E8x*V;lFl `^J
       (SID_NAME =orcl)ITPUB个人空间8k(O2u \.],`
   )
k%E9J0r,]JY0)ITPUB个人空间3D.J,Z%~&}yY1N
该文件表明数据库是单实例的,实例名为orcl,向外提供了两个服务:orcl和orcl1ITPUB个人空间 }z+z!K\1T-f)NM`
三、动态注册

动态注册是ORACLE实例在启动时,或使用命令ALTER SYSTEM REGISTER 或每隔一分钟,实例的PMON会向监听进行注册,告知监听,实例的服务名,实例名等信息。
5H(}bUnj6B0动态注册是在instance启动的时候PMON进程根据init.ora中的instance_name,service_names两个参数将实例和服务动态注册到listener中。
C2?.w:O6[3o0首先要在init.ora中指定instance_name,service_names两个参数的值。在sqlplus下通过show parameter service_names 和show parameter instance_name可以查看这两个参数的值。ITPUB个人空间a(K/^9D$s ejQ jE z
注册到监听器中的实例值从init.ora文件中的instance_name参数取得。如果该参数没有设定值,那么它将取init.ora文件中的db_name的值。
X$C4p$DP0注册到监听器中的服务值从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被注册到监听器中:
+De}:h+be1q0db_domain=oracle.comITPUB个人空间G?1a}/dN]!R1D3\(Y
service_names=orcl ;
"S,eNt*N3c5}0采取动态注册方法时,listener.ora中的内容如下:
`;RJI9Xq/E%Z"X0SID_LIST_LISTENER =
ZFWFs0  (SID_LIST =ITPUB个人空间6YH(_Lfg9Kb4o
    (SID_DESC =ITPUB个人空间I[S y,Ffpxz0] S
       (SID_NAME = PLSExtProc)ITPUB个人空间'\LNwj G)G
       (ORACLE_HOME = D:\oracle\product\10.2.0\db_1)
(cR y;OY+i&V/K${+z0       (PROGRAM = extproc)ITPUB个人空间0^,p9Hk]7{'Z0? J@
    )ITPUB个人空间HxoReKl;s
)
w;y nQw3MRS&n$E0
cSQXxhb0可选择的是,您可以在service_names参数中指定多个服务值,值之间用逗号格开,这对于共享服务器配置是很有用的。ITPUB个人空间Hp l }4x^t
动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、协议是TCP),如果需要向非默认监听注册,则需要配置local_listener参数!
oF[rLj0
0S]'f4Ulk'?0如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种情况下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最好在所有的数据库启动之前先启动监听器,这样就会避免没有显式设置service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的情况。
uf,oe8e%pDA \[w0为初始化参数service_names和instance_name设置显式的值是个值得可取的方法和建议。因为如果监听器在数据库运行过程中要重新启动,仅当你在init.ora文件中显式地设置了service_names和instance_name的值时,每个数据库的PMON进程才会在很短的时间之内完成动态注册。ITPUB个人空间x;[Nd.HI
四、查询某服务是静态注册还是动态注册ITPUB个人空间2B \+f$LA^d @
可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。
.ns3~|kX0ITPUB个人空间H%VT"rX*@u4P[
实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。ITPUB个人空间0RwH#R ^)L ^
动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册的数据库都会动态地从监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的回退(fallback)和负载平衡。

分享到:
评论

相关推荐

    Oracle Listener 动态注册 与 静态注册

     相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立...

    Oracle listener详解

    Oracle listener详解 包括静态注册和动态注册 OS认证和口令文件认证方法等

    TcpListener 和TcpClient使用总结

    TcpListener类以同步阻塞方式提供于监听和接收外来连接请求的方法。 TcpClient类实现了使用发送和接收数据的套接字。 在c# .NET中,远程连接被表示为流,所以可以用流处理方式读取和写入而进行通信。

    Oracle静态注册与动态注册详解

     相当于是这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端需要连接数据库时,只需要提供服务名,就可以建立...

    杂记(一):Listener、Filter和工具

    杂记(一):Listener、Filter和工具 杂记(一):Listener、Filter和工具

    Aynchronous TCPListener 异步 server和client学习

    Aynchronous TCPListener 异步 server和client学习资源。可以借鉴

    Servlet中的八大Listener

    Servlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的八大Listener.docServlet中的...

    基于Spring的listener和Task

    基于Spring的listener和Task,Spring的初始化和定时任务(Task)

    Filter和Listener

    Filter和Listener区别

    SpringBoot整合Listener的两种方式.docx

    1.通过注解扫描完成Listener组件的注册 1.创建一个类实现 ServletContextListener (具体实现哪个Listener根据情况来判断) 2.在类上加入注解 @WebListener 3.重写 contextInitialized() 与 contextDestroyed...

    TcpClient TcpListener Demo

    TcpClient TcpListener Demo 案例 TcpClient TcpListener Demo 案例 TcpClient TcpListener Demo 案例 TcpClient TcpListener Demo 案例 QQ:574311505

    C# TcpClient和TcpListener通讯

    C# 用TcpClient和TcpListener实现的功能 可以和网络通讯 此次只为了实现事件接受功能 希望能一起学习

    TcpListener 监听服务端

    TcpListener 监听服务端,可实现多客户端连接

    JavaWeb开发技术-Listener监听器.pptx

    Listener监听器 JavaBean Servlet Jsp XML HTML JAVA WEB开发技术 Listener监听器 事件监听器用于对程序中发生的事件进行监听,在监听的过程中会涉及几个重要组成部分: 事件(Event) 事件源 事件处理器 事件监听器...

    listener监听器demo

    listener监听器小例子

    java jsp listener小用法

    java jsp listener小用法,记录登录次数。

    TcpListener简易交互

    TcpListener和TcpClient模拟客户端和服务端交互,以及重连

    mac_Listener.dmg

    mac_Listener

    Android Listener侦听的N种写法

    Android Listener侦听的N种写法

    Oracle监听器维护管理v1.1

    四、监听动态注册和静态注册 14 1、注册 14 2、动态注册 15 3、自定义端口的动态注册 16 3.1 增加tnsname.ora服务注册 16 3.2修改local_listener参数注册 17 4、静态注册 17 5、查看注册类型 18 五、监听日志基本...

Global site tag (gtag.js) - Google Analytics