oracle静态监听和动态监听 (2010-01-04 18:24)
分类: 系统管理
oracle静态监听和动态监听
一、什么是注册?
注册就是将数据库作为一个服务注册到监听程序。客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名
就可以申请连接到数据库。这个服务名可能与实例名一样,也有可能不一样。
在数据库服务器启动过程中,数据库服务器会向监听程序注册相应的服务(无论何时启动一个数据库,默认地都有两条信息注册
到监听器中:数据库服务器对应的实例和服务。)
相当于是这样:在数据库服务器和客户端之间有一监听程序(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下通过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)和负载平衡。
分享到:
相关推荐
本教程主要讲解了Oracle数据库的静态监听和动态监听两种方式,以及它们的工作原理和配置。 一、注册概念 注册是指数据库作为服务向监听程序报告其存在。这一过程使得客户端在连接数据库时,只需要知道服务名,而...
Oracle 监听器的配置包括静态注册和动态注册两种方式。静态注册是通过监听器的配置文件(listener.ora)来实现的,而动态注册是通过 Oracle 实例的参数文件来实现的。 5. Oracle 监听器常见问题和解决方法 Oracle ...
网上有很多关于oracle 监听静态注册的文章,但大多都是简单说说,并没有详细的例子,这里,将结合linux as4 下的oracle 10gR2.0.1 举一个具体的例子 1、在 $ORACLE_HOME/network/admin/listener.ora 文件中加入一...
总结来说,监听配置是数据库管理中的基础工作,理解动态和静态注册的区别以及如何在不同场景下配置,对于优化数据库性能和保证系统稳定性至关重要。通过正确配置,可以确保服务的可发现性,同时增强系统的安全性和可...
### 在Linux上安装Oracle 10g 创建监听 创建数据库 #### 安装前的环境配置 在进行Oracle 10g的安装之前,需要对Linux系统进行一系列的配置,以确保Oracle能够顺利运行。 ##### 1. 配置全局与用户级别的环境变量 ...
Oracle数据库监听是客户端和数据库服务器之间通信的基础组件,负责接收客户端的连接请求,并将请求转发至相应的数据库实例。监听充当了一个“桥梁”的角色,对于数据库的远程连接和管理至关重要。在Oracle数据库的...
四、监听动态注册和静态注册 1. 注册:实例可以通过动态或静态方式向监听器注册服务名。 2. 动态注册:实例启动后自动向监听器注册,适用于多实例环境,便于故障检测和转移。 3. 自定义端口的动态注册:允许实例在非...
Oracle 监听器相关的知识点: Oracle 监听器是Oracle...监听器的工作原理和注册机制对于理解Oracle数据库的网络通信至关重要,它们确保了客户端能正确连接到相应的数据库实例,并且能够灵活适应不同场景下的连接需求。
Oracle数据库注册的核心是监听程序(Listener),它作为数据库服务器和客户端之间的中介,管理着数据库实例和服务的映射关系。当客户端请求连接时,只需提供服务名,监听程序就能根据配置找到对应的数据库实例。默认...
在Oracle数据库系统中,"静态注册"和"动态注册"是指数据库实例与监听器(Listener)之间通信的不同方式。这两种注册方法对Oracle客户端如何找到并连接到正确的数据库实例至关重要。 首先,ORACLE_SID是一个环境变量,...
### Oracle 一个实例配置多个监听 #### 背景与目的 在Oracle 11g环境中,有时出于网络隔离、安全或性能优化等需求,可能需要为同一个数据库实例配置多个监听器。这样做可以让不同的应用程序通过不同的端口访问同一...
Oracle 静态和动态注册 Oracle 注册是将数据库作为一个服务注册到监听器,客户端不需要知道数据库名和实例名,只需要知道该数据库对外提供的服务名就可以申请连接到该数据库。Oracle 注册可以分为静态注册和动态...
点击开始 —— 》 程 序 —— 》 Oracle - OraDb10g_home1—— 》 配 置 和 移 植 工 具 —— 》 NetConfiguration Assistant,开始配置监听。 数据库创建 数据库创建是指创建 Oracle 数据库的过程。在安装完成后...
Oracle 11g2版本中,监听器配置项中增加了如ENABLE_GLOBAL_DYNAMIC_ENDPOINT_LISTENER_SCAN1、ENABLE_GLOBAL_DYNAMIC_ENDPOINT_LISTENER和ENABLE_GLOBAL_DYNAMIC_ENDPOINT_LISTENER_WFG等用于启用全局动态端点的设置...
Oracle 监听器(Listener)是Oracle数据库系统中不可或缺的一部分,它主要负责管理和协调数据库实例与客户端应用程序之间的网络通信。监听器运行在数据库服务器上,监听来自客户端的连接请求,并根据配置将这些请求...
在Linux操作系统中,主机名是标识服务器的重要标识符,它在很多网络服务中都有应用,包括Oracle数据库的监听服务和企业管理器(Enterprise Manager, EM)。当我们需要更改Linux主机名时,这可能会对运行在该系统上的...
Oracle监听器(Listener)是Oracle数据库系统中至关重要的组件,它负责管理客户端和数据库服务器之间的网络通信。监听器通过监听特定的网络端口,接收来自客户端的连接请求,并根据配置进行响应。理解监听器的工作...
### Oracle数据库监听配置浅析与...通过对监听服务的基本配置、高级设置以及常见故障的分析,我们可以更好地理解和优化Oracle数据库的网络连接机制。希望本文提供的信息能够帮助读者有效地管理和维护Oracle数据库系统。