oracle registers,oracle dynamically register service(动态注册服务)

ORACLE 10G 中的静态及动态注册问题

最近发现偶的oracle 10g r1版本,想切换到归档模式时,在shutdown 后,再startup

后,居然出现如

下错误:

ORA-12528:TNS:listener: all appropriate instances are blocking new

connections

查了下,有的说是10g r1的问题,要10g r2就解决,但我没R2,只能再看,原来发现主要是

linster.ora中的静态注册和动态注册的问题,下面转一文介绍:

一、什么是注册?

注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数

据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。

在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默

认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)

相当于是这样:在数据库服务器和客户端之间有一监听程序(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

在tnsnames.ora文件中的CONNECT_DATA部分,可分别选择SERVICE_NAME=Ora8或SID=test为客户端

提供连接。

对于配置非1521监听端口,只能选择静态注册方式。

三、动态注册

动态注册是在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)和负载平衡。

因此,由于Listener动态监听,实例虽然启动,但没有注册到监听。实例是通过PMON进程注册到监听

上的,而PMON进程需要在MOUNT状态下才会启动。所以造成了上面的错误,为了方便,只能将其改为静

态监听

修改NETWORK\ADMIN下的listner.ora,改为

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC

=

(SID_NAME = PLSExtProc)

(ORACLE_HOME = e:\oracle10g)

(PROGRAM = extproc)

)

(SID_DESC =

(GLOBAL_DBNAME = oracle)

(ORACLE_HOME = e:\oracle10g)

(SID_NAME = oracle)

)

)

要注意的是=号左右两边的空格,否则会出错,然后再用lsnrctl

start等来启动,这次的话,可以很顺利地

解决shutdown后再startup mount的问题了.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值