Oracle监听注册的实现

 更新时间:2023年12月14日 15:45:52   作者:Tzq@2018  
Oracle数据库的注册监听功能是Oracle数据库管理的一个重要组成部分,它允许数据库实例接收来自客户端请求,并且可以自动恢复数据库服务,感兴趣的可以了解一下

一、静态注册

静态注册就是实例启动时读取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进程才会在很短的时间之内完成动态注册。

到此这篇关于Oracle监听注册的实现的文章就介绍到这了,更多相关Oracle监听注册内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • oracle 服务启动,关闭脚本(windows系统下)

    oracle 服务启动,关闭脚本(windows系统下)

    Windows下的批出理程序,就是dos命令的集合,我们也可以通过运行程序里的命令来开启服务.
    2009-07-07
  • Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决

    Oracle dbca时报:ORA-12547: TNS:lost contact错误的解决

    这篇文章主要给大家介绍了关于Oracle在dbca时报:ORA-12547: TNS:lost contact错误的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-11-11
  • Oracle数据库中创建自增主键的实例教程

    Oracle数据库中创建自增主键的实例教程

    Oracle的字段自增功能,可以利用创建触发器的方式来实现,接下来我们就来看看Oracle数据库中创建自增主键的实例教程,需要的朋友可以参考下
    2016-05-05
  • Oracle Number型的深入理解

    Oracle Number型的深入理解

    本篇文章是对Oracle中Number型进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • ORACLE 最大连接数的问题

    ORACLE 最大连接数的问题

    客户端连接数据库报错
    2009-07-07
  • Oracle数据库表中字段顺序的修改方法

    Oracle数据库表中字段顺序的修改方法

    这篇文章主要给大家介绍了关于Oracle数据库表中字段顺序的修改方法,在介绍修改的方法之前先给大家介绍了Oracle数据库表新建字段的方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-11-11
  • Oracle 的入门心得 强烈推荐

    Oracle 的入门心得 强烈推荐

    oracle的体系太庞大了,对于初学者来说,难免会有些无从下手的感觉,什么都想学,结果什么都学不好,所以把学习经验共享一下,希望让刚刚入门的人对oracle有一个总体的认识,少走一些弯路。
    2009-05-05
  • Oracle 数据库中的全文搜索整体流程分析

    Oracle 数据库中的全文搜索整体流程分析

    Oracle 是一种功能强大的关系型数据库管理系统,它提供了各种功能来处理和管理大量的数据,这篇文章主要介绍了Oracle 数据库中的全文搜索功能,需要的朋友可以参考下
    2024-04-04
  • Oracle 11G数据库审计监控设置指南

    Oracle 11G数据库审计监控设置指南

    Oracle 11G数据库审计监控涉及创建独立表空间、查看审计信息、迁移表空间、开启审计及审计维护等步骤,合理规划审计表空间有助于管理审计数据,避免影响系统表空间,审计监控涵盖审计数据迁移、自动清理、权限分配、查询审计类型等方面,确保数据库安全性能
    2024-10-10
  • rman配置及rman常用命令操作

    rman配置及rman常用命令操作

    这篇文章主要介绍了rman配置及rman常用命令操作,包括校验备份信息、查看备份、删除备份等,需要的朋友可以参考下
    2014-03-03

最新评论