一、什么是注册?
注册就是将数据库做为一个服务注册到监听程序。客户端不须要知道数据库名和实例名,只须要知道该数据库对外提供的服务名就能够申请链接到数据库。这个服务名可能与实例名同样,也有可能不同。在数据库服务器启动过程当中,数据库服务器会向监听程序注册相应的服务(不管什么时候启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)至关因而这样:在数据库服务器和客户端之间有一监听程序(Listener),在监听程序中,会记录相应数据库对应的服务名(一个数据库可能对应有多个服务名),当客户端须要链接数据库时,只须要提供服务名,就能够创建客户端和服务器之间的链接。
二、静态注册
静态注册就是实例启动时读取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下经过showparameterservice_names和showparameterinstance_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、端口是152一、协议是TCP),若是须要向非默认监听注册,则须要配置local_listener参数!若是没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行以后启动时,动态注册才会发生;在这种状况下,若是监听器后来发生了重启,动态注册信息将会丢失。显然,最好在全部的数据库启动以前先启动监听器,这样就会避免没有显式设置service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的状况。为初始化参数service_names和instance_name设置显式的值是个值得可取的方法和建议。由于若是监听器在数据库运行过程当中要从新启动,仅当你在init.ora文件中显式地设置了service_names和instance_name的值时,每一个数据库的PMON进程才会在很短的时间以内完成动态注册。
四、查询某服务是静态注册仍是动态注册
可使用命令lsnrctlstatus来查看某服务是静态注册仍是动态注册。
实例状态为UNKNOWN值时代表此服务是静态注册的设置。这时监听器用来代表它不知道关于该实例的任何信息,只有当客户发出链接请求时,它才检查该实例是否存在。
动态注册的数据库经过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。无论关闭什么时候数据库,动态注册的数据库都会动态地从监听器注销,而与之相关的信息将从状态列表中消失。这样,无论数据库是在运行仍是已经关闭,监听器老是知道它的状态。该信息将被用于链接请求的回退(fallback)和负载平衡。