`
wxb880114
  • 浏览: 681977 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Oracle Listener动态注册与静态注册(转载)

阅读更多
一.什么是注册

注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。

  在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册到监听器中:数据库服务器对应的实例和服务。)

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

  

二、动态注册

  动态注册是在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的值。如果在RAC中配置,您必须将集群中每个实例的instance_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),因为pmon只会动态注册port等于1521的监听,否则pmon不能动态注册listener,如果需要向非默认监听注册,则需要配置local_listener参数!



将监听的信息添加到tnsnames.ora  文件中。 注意,是tnsnames.ora 文件, 因为pmon在动态注册监听时要从tnsnames.ora中读取相关信息。

LISTENER =

(DESCRIPTION =

(ADDRESS = (PROTOCOL = TCP)(HOST = DaveDai)(PORT = 1522))

)



然后以sys用戶运行:

SQL> alter system set local_listener=listener;

SQL> alter system register;



或者:

SQL> alter system set LOCAL_LISTENER='(ADDRESS = (PROTOCOL = TCP)(HOST = DaveDai)(PORT = 1522))';

SQL> alter system register;

系统已更改。



$lsnrctl status listener


  如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种情况下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最好在所有的数据库启动之前先启动监听器,这样就会避免没有显式设置 service_names和instance_name的值时,若重启监听器带来的动态注册信息丢失的情况。


为初始化参数service_names和instance_name设置显式的值是个很好的实践,尽管如果您没有设置它们,Oracle也会为动态注册而生成默认值(基于db_name和db_main)。这样做的原因是,如果监听器在数据库启动之后重新启动,其动态注册行为将会有一些微妙的区别.如果监听器在数据库运行之后重新启动,你们仅当您在init.ora文件中显式地设置了service_names和instance_name的值时,每个数据库的PMON进程才会在很短的时间之后自动注册数据库。



如果需要执行连接时故障转移或负载均衡,或者想要在RAC中配置在实例之间透明地分布连接,那么使用service_names参数将是必要的。为启用这些功能,您只需要将每个实例的数据库参数文件中的service_names设置为同一个值,并在客户端连接请求的service_name设置中引用该值。


如果没有显式设置service_names和instance_name的值,那么仅当数据库在监听器运行之后启动时,动态注册才会发生;在这种情况下,如果监听器后来发生了重启,动态注册信息将会丢失。显然,最后在启动任何数据库之前启动服务器上的监听器,并完全避免监听器的重启。



另外,您还可以在SQL*PLUS中使用命令:

SQL>ALTER SYSTEM REGISTER;

在数据库打开时的任何时候,手工地在监听器中注册服务值。这个命令对于替换因监听器重启而丢失地服务值很有用,并且它所注册地值与在数据库启动时由动态注册所设置的值完全一样。



动态监听:

  oracle监听器运行后,oracle实例在open时,会动态向监听程序注册其service_names和instance_name。

  其中instance_name默认是:db_name

  而service_names默认是:db_name.db_domain



  三、静态注册
  静态注册就是实例启动时读取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_name



既然有动态监听为什么还要静态监听呢?原因如下:

  1.监听器不是最早启动,oracle实例先启动

  2.监听器重启

  3.oracle实例没有open






  四、查询某服务是静态注册还是动态注册

  可以使用命令lsnrctl status来查看某服务是静态注册还是动态注册。

  实例状态为UNKNOWN值时表明此服务是静态注册的设置。这时监听器用来表明它不知道关于该实例的任何信息,只有当客户发出连接请求时,它才检查该实例是否存在。

  动态注册的数据库通过状态信息中的状态READY或状态BLOCKED(对于一个备用数据库)来指明。不管关闭何时数据库,动态注册的数据库都会动态地从 监听器注销,而与之相关的信息将从状态列表中消失。这样,不管数据库是在运行还是已经关闭,监听器总是知道它的状态。该信息将被用于连接请求的回退(fallback)和负载平衡。






原文:http://blog.csdn.net/tianlesoftware/article/details/5543166
注: 整理自网络
分享到:
评论

相关推荐

    Oracle Listener 动态注册 与 静态注册

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

    Oracle listener详解

    静态注册和动态注册是监听器管理数据库服务的两种方式。静态注册是预先在监听器配置文件`listener.ora`中定义服务和实例,监听器会主动查找并维护这些服务的状态。在静态注册中,`GLOBAL_DBNAME`字段用于标识数据库...

    静态注册 动态注册

    了解和掌握静态注册与动态注册的差异和应用场景,对于管理和维护Oracle数据库系统的稳定性和性能至关重要。例如,在多实例环境中,动态注册可以简化管理,而静态注册可能更适合于对安全性有特殊要求或者需要精确控制...

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

    Oracle数据库的注册方式主要包括静态注册和动态注册,这两种方式都是为了使得客户端能够通过服务名连接到数据库实例,而无需直接知道具体的数据库名和实例名。本文将深入解析这两种注册方式。 一、概述 Oracle...

    oracle注册.docx

    Oracle 静态和动态注册 Oracle 注册是将数据库作为一个服务注册到监听器,客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到该数据库。Oracle 注册可以分为静态注册和动态...

    Oracle数据库教程——oracle静态监听和动态监听借鉴.pdf

    总结来说,Oracle数据库的监听程序通过静态和动态注册两种方式确保了客户端能够有效地连接到数据库。静态注册适用于固定配置,而动态注册则适用于需要动态调整服务和实例信息的环境。理解这两种方式的工作原理对于...

    监听配置的概念动态注册静态注册及各种场景的配置实例

    本文主要探讨了监听的概念,动态注册与静态注册的区别,以及在不同场景下的配置实例。 监听器(Listener)是Oracle数据库系统中一个核心组件,它负责接收来自客户端的连接请求,并将这些请求转发到相应的数据库实例...

    Oracle监听器维护管理v1.1

    本文档详细介绍了Oracle监听器的工作原理、主要功能、基本操作、动态注册与静态注册、监听日志管理和分析以及针对远程监听的安全防范措施。 一、监听器工作原理 监听器主要负责接收客户端的连接请求,它在操作系统...

    Oracle静态监听注册详解

     1、在 $ORACLE_HOME/network/admin/listener.ora 文件中加入一个静态注册的节点 [oracle@prudent oracle]$ cd $ORACLE_HOME/network/admin [oracle@prudent admin]$ vi listener.ora # listener.ora Network ...

    Oracle 监听器 Listener资料.docx

    实例可以通过动态或静态注册方式将自身信息告知监听器,以便客户端能根据服务名找到正确的数据库实例。 - **错误转移(Failover)**:在Real Application Clusters (RAC)环境下,如果一个实例发生故障,监听器能...

    oracle监听器深入讲解

    静态注册是通过监听器的配置文件(listener.ora)来实现的,而动态注册是通过 Oracle 实例的参数文件来实现的。 5. Oracle 监听器常见问题和解决方法 Oracle 监听器可能会出现的一些常见问题包括监听器无法启动、...

    说说Oracle监听器(二)

    Oracle监听器还涉及到注册机制,分为静态注册和动态注册。静态注册在启动监听器时就指定要监听的实例和服务名,即使实例尚未启动。静态注册的配置在listener.ora文件中,每个SID_DESC代表一个配置项,包括实例名...

    centos7离线安装oracle12c

    - **用户与权限**:创建一个用于运行Oracle服务的非root用户,如`oracle`,并将其添加到`dba`和`oinstall`组。 2. **安装必要的软件包**: - **开发工具**:安装`yum groupinstall "Development Tools"`,包含...

    Oracle一个实例配置多个监听

    - **动态注册**: 使用`local_listener`参数将服务动态地注册到监听器上。 - **静态注册**: 在`listener.ora`文件中直接指定服务名和服务对应的监听器。 **动态注册示例**: 1. **定义`ALL_LISTENER`**: 在`tnsnames....

    远程登录并启动oracle数据库 解决ORA-01031

    2. **目标数据库已静态注册到Listener**:这意味着目标数据库的信息(如端口号、协议等)已配置在Listener的配置文件(通常是listener.ora)中。 3. **客户端已配置好tnsnames.ora文件**:这个文件包含了客户端连接...

    Oracle实战攻略之监听的故障处理方法和优化思路

    而静态注册则是在listener.ora配置文件中明确指定监听服务与Oracle实例的对应关系,这种方式通常更为稳定可靠,需要DBA手动配置,但避免了动态注册可能出现的延迟或失败问题。 监听故障处理方法主要包括检查监听的...

Global site tag (gtag.js) - Google Analytics