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

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

一致,且可以注册多个服务。
    注册可以分为静态注册与动态注册,下面分别介绍静态注册和动态注册。
二、静态注册
    静态注册就是预先配置好listener.ora文件,配置信息如下:
#listener.ora
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = /u01/app/oracle/product/10.2/db_1)
      (PROGRAM = extproc)
    )
    (SID_DESC =
      (SID_NAME = orcl)##数据库的实例名
      (ORACLE_HOME = /u01/app/oracle/product/10.2/db_1)##监听程序所在路径
      (GLOBAL_DBNAME = test01)##数据库对外提供的服务名
    )
  )

LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = db01)(PORT = 1521))
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
    )
  )

当用户通过客户端申请连接数据库时,首先通过监听程序读取listener.ora中的配置信息(无论数据库

是否启动,用户的连接请求都会通过监听程序的检查,因为静态监听是无法识别数据库的启动状态的

,只有用户试图连接数据库时,数据库才会返回相关信息。)

下面我们来看下数据库处于打开和关闭状态时,服务test01的实例状态:
1、打开状态
[oracle@db01 admin]$ lsnrctl status

LSNRCTL for Linux: Version 10.2.0.1.0 - Production on 16-OCT-2013 06:58:27

Copyright (c) 1991, 2005, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=db01)(PORT=1521)))
STATUS of the LISTENER
------------------------
Alias                     LISTENER
Version                   TNSLSNR for Linux: Version 10.2.0.1.0 - Production
Start Date                16-OCT-2013 06:39:09
Uptime                    0 days 0 hr. 19 min. 18 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   /u01/app/oracle/product/10.2/db_1/network/admin/listener.ora
Listener Log File         /u01/app/oracle/product/10.2/db_1/network/log/listener.log
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=db01)(PORT=1521)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC0)))
Services Summary...
Service "PLSExtProc" has 1 instance(s).
  Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
Service "orcl" has 1 instance(s).
  Instance "orcl", status READY, has 1 handler(s) for this service...
Service "orclXDB" has 1 instance(s).
  Instance "orcl", status READY, has 1 handler(s) for this service...
Service "orcl_XPT" has 1 instance(s).
  Instance "orcl", status READY, has 1 handler(s) for this service...
Service "test01" has 1 instance(s).
  Instance "orcl", status UNKNOWN, has 1 handler(s) for this service...

=>实例orcl的状态为unknown
The command completed successfully

此时当用户通过客户端连接数据库时:
SQL> conn system/hat@test01
已连接。

2、关闭状态:
[oracle@db01 admin]$ lsnrctl status

LSNRCTL for Linux: Version 10.2.0.1.0 - Production on 16-OCT-2013 06:54:44

Copyright (c) 1991, 2005, Oracle.  All rights reserved.

Connecting to (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=db01)(PORT=1521)))
STATUS of the LISTENER
------------------------
Alias                     LISTENER
Version                   TNSLSNR for Linux: Version 10.2.0.1.0 - Production
Start Date                16-OCT-2013 06:39:09
Uptime                    0 days 0 hr. 15 min. 35 sec
Trace Level               off
Security                  ON: Local OS Authentication
SNMP                      OFF
Listener Parameter File   /u01/app/oracle/product/10.2/db_1/network/admin/listener.ora
Listener Log File         /u01/app/oracle/product/10.2/db_1/network/log/listener.log
Listening Endpoints Summary...
  (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=db01)(PORT=1521)))
  (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)(KEY=EXTPROC0)))
Services Summary...
Service "PLSExtProc" has 1 instance(s).
  Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...
Service "test01" has 1 instance(s).
  Instance "orcl", status UNKNOWN, has 1 handler(s) for this service...

=>实例orcl的状态为unknown
The command completed successfully

此时当用户通过客户端连接数据库时:
SQL> conn system/hat@test01
ERROR:
ORA-01034: ORACLE not available
ORA-27101: shared memory realm does not exist
Linux Error: 2: No such file or directory
由此可知,用户的连接请求通过了监听的检查,但数据库没有打开,于是就返回了ora-01034的错误。

通过上面的实验,验证了当监听静态注册时,服务的实例状态均为unknown,监听程序无法知道数据库

是否处于打开状态。

三、动态注册
    动态注册就是不需预先配置listener.ora文件,而是instance在启动的时候PMON进程根据

init.ora中的instance_name、service_names两个参数将实例和服务动态的注册到listener中。
    注册到监听器中的实例名从init.ora文件中的instance_name参数取得。如果该参数没有设定值,

那么它将取init.ora文件中的db_name值。
    注册到监听器中的服务名从init.ora文件中的参数service_names(该参数可以设置多个值,且值

以逗号分隔)和db_domain取得。如果service_names参数没有设定值,数据库将取init.ora文件中的

db_name值。
    采取动态注册时,listener.ora配置如下:
#listener.ora
SID_LIST_LISTENER =
  (SID_LIST =
    (SID_DESC =
      (SID_NAME = PLSExtProc)
      (ORACLE_HOME = /u01/app/oracle/product/10.2/db_1)
      (PROGRAM = extproc)
    )
  )

LISTENER =
  (DESCRIPTION_LIST =
    (DESCRIPTION =
      (ADDRESS = (PROTOCOL = TCP)(HOST = db01)(PORT = 1521))
      (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
    )
  )

动态注册默认只注册到默认的监听器上(名称是LISTENER、端口是1521、协议是TCP),如果需要向

非默认监听注册,则只需要配置local_listener参数。

四、如何区分静态注册与动态注册
方法一:通过lsnrctl status监测
静态注册的监听实例状态为unknown,动态注册的监听实例状态为ready
方式二:查看listener.ora文件
listener.ora文件中添加了如下信息的为静态注册,没有添加为动态注册
(SID_DESC =
  (SID_NAME = orcl)##数据库的实例名
  (ORACLE_HOME = /u01/app/oracle/product/10.2/db_1)##监听程序所在路径
  (GLOBAL_DBNAME = test01)##数据库对外提供的服务名
)

注:1、由于动态注册监听是通过pmon进程来动态添加的,因此一旦数据库关闭,那么动态注册的服务便立即从监听程序中消除。
2、如果想远程启动数据库,需要通过静态注册。

listener之一二相关推荐

  1. The listener supports no services

    记录一个重启服务器后Oracle启动监听服务报错:The listener supports no services 原因:数据库实例没有注册到listener 解决办法:在listener.ora里 ...

  2. listener.ora、sqlnet.ora、tnsnames.ora 详解

    三个配置文件 listener.ora.sqlnet.ora.tnsnames.ora,都是放在$oracle_home\network\admin目录下. 重点:三个文件的作用和使用 sqlnet. ...

  3. oracle实例没有连到监听上6,oracle LISTENER未监听到oracle实例问题解决

    oracle LISTENER未监听到oracle实例问题解决 LISTENER = (DESCRIPTION_LIST = (DESCRIPTION = (ADDRESS = (PROTOCOL = ...

  4. java servlet filter_Java的Servlet、Filter、Interceptor、Listener

    写在前面: 使用Spring-Boot时,嵌入式Servlet容器可以通过扫描注解(@ServletComponentScan)的方式注册Servlet.Filter和Servlet规范的所有监听器( ...

  5. Google Test(GTest)使用方法和源码解析——Listener技术分析和应用

    在<Google Test(GTest)使用方法和源码解析--结果统计机制分析>文中,我么分析了GTest如何对测试结果进行统计的.本文我们将解析其结果输出所使用到的Listener机制. ...

  6. Listener监听器之HttpSessionListener

    编写一个OnlineUserListener. package anni; import java.util.List; import javax.servlet.ServletContext; im ...

  7. Java中Filter、Servlet、Listener的学习

    1.Filter的功能filter功能,它使用户可以改变一个 request和修改一个response. Filter 不是一个servlet,它不能产生一个response,它能够在一个reques ...

  8. TNS-01201: Listener cannot find executable /u01/oracle/bin/extproc for SID orcl Listener failed to

    文章目录 问题描述 原因 解决过程 结果 问题描述 原因 listener.ora文件中ORACLE_HOME的路径错了,导致按照这个路径找不到extproc 解决过程 首先去找ORACLE_HOME ...

  9. CentOS报错:TNS-12541: TNS:no listener TNS-12560: TNS:protocol adapter error TNS-00511: No listener

    问题描述 原因 listener.ora中的ORACLE_HOME错了 解决 这个错误当时是和另一条指令lsnrctl start的错误一起报的,那个已解决,详细做法请各位移步我的另一篇博客 http ...

最新文章

  1. java initcause_Java 异常
  2. [转]VSTO Office二次开发RibbonX代码结构
  3. H2DBEngine——Driver的设计与实现
  4. Windows Server 2003 备份和恢复的最佳做法
  5. vim关闭所有折叠命令
  6. 华三交换机ping大包命令_华三交换机常用命令
  7. 01:MongoDB基础
  8. 快速入门:github发布windows版
  9. 超级仿制药行业调研报告 - 市场现状分析与发展前景预测(2021-2027年)
  10. cad怎么查找未闭合_CAD应该怎么测量图形?未封闭、不规则的图形要这样测量
  11. 第二章 Python数据类型和运算符
  12. 每日新闻丨阿里上市成港股第三大IPO,市值超腾讯;网易回应“暴力裁员”后股价下跌2.38%...
  13. 程序员小故事-战术上的勤奋和战略上的懒惰
  14. 0x000000c5(0X000000C5蓝屏是什么意思)
  15. 显卡内存一直被占用解决方式
  16. adb安装配置及连接手机
  17. [AHK]输入法状态提示,中文状态提示“中”,英文状态提示“EN”[转]
  18. 人工智能和AI到底是什么??浅谈人工智能和AI
  19. mysql point 经纬度_lbs - Mysql POINT类型数据,怎么计算经纬度偏差
  20. maven常用scope作用域说明

热门文章

  1. 数据标注平台分析与使用经验
  2. 大脸猫SEO:网站排名真的是我们所需要的吗?
  3. Android进程间通信 深入浅出AIDL(一)
  4. 怎么看待ChatGPT封号这件事呢?
  5. TX Text Control 30.0
  6. Unity材质球和静态物体导致的内存泄漏
  7. 小鸟从不怕树枝折断,因为它有翅膀
  8. NOI:2722 和数
  9. intouch制作历史趋势公用弹窗
  10. 卫哲:阿里人才秘诀,谨慎下放招聘权、让95后心甘情愿