listener之一二

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

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

一致,且可以注册多个服务。
    注册可以分为静态注册与动态注册,下面分别介绍静态注册和动态注册。
二、静态注册
    静态注册就是预先配置好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、如果想远程启动数据库,需要通过静态注册。

 

<think>我们正在讨论JavaScript中的事件监听器(EventListener)。根据用户的问题,他们想了解JavaScript事件监听器的教程和使用方法。 根据提供的引用,我们可以总结以下关键点: 1. 事件监听器用于监听HTML DOM中发生的事件(如点击、鼠标移动、键盘按下等)并执行相应的操作。 2. 使用addEventListener()方法添加事件监听器,它有三个参数:事件类型(不带'on'前缀)、事件发生时要调用的函数、以及一个可选的布尔值(用于指定事件处理阶段,默认为false,即在冒泡阶段处理)。 3. 同一个元素可以添加多个事件监听器,包括相同类型的事件。 4. 移除事件监听器使用removeEventListener()方法,注意需要传递与添加时相同的函数引用(因此不能使用匿名函数,除非保存了引用)。 5. 事件监听器相比直接在HTML标签内写事件属性(如onclick)更灵活,且不覆盖已有的事件处理函数。 此外,引用中提供了简单的代码示例,我们可以在此基础上扩展。 我们将按照以下结构回答: 1. 基本概念:什么是事件监听器,为什么使用它。 2. 使用方法:添加事件监听器(包括参数说明),多个事件监听器,移除事件监听器。 3. 实际应用示例:包括响应点击事件、动态添加事件监听器等。 4. 注意事项(如兼容性问题,旧版IE的attachEvent等,但现代浏览器基本都支持addEventListener)。 由于用户要求教程和使用方法,我们将提供详细的代码示例和解释。 注意:引用中提到的旧版IE需要特殊处理,但考虑到现在IE已逐渐被淘汰,我们主要介绍标准方法,但会简要提及兼容性问题。 同时,根据引用[3],我们还可以提到事件监听器在动态元素更新上的应用,即事件委托(Event Delegation)技术,它允许我们为尚未创建的元素动态绑定事件。 下面开始组织回答。</think>### JavaScript 事件监听器(EventListener)教程与使用方法 #### 一、基本概念 事件监听器(EventListener)是 JavaScript 中用于**监听和响应 HTML DOM 事件**的核心机制。通过 `addEventListener()` 方法,可为页面元素绑定交互行为,例如: - 用户操作:点击(`click`)、键盘输入(`keydown`) - 系统事件:页面加载(`load`)、元素内容变化(`change`) - 设备反馈:鼠标移动(`mousemove`)、触摸屏滑动(`touchmove`) > **优势**:相比直接在 HTML 标签中写 `onclick` 属性,事件监听器支持**多个处理函数**,且不会覆盖已有事件[^4]。 #### 、核心语法 ```javascript element.addEventListener(eventType, callbackFunction, [useCapture]); ``` - **参数说明**: - `eventType`:事件类型字符串(**不带 `on` 前缀**),如 `"click"`, `"keyup"` - `callbackFunction`:事件触发时执行的函数 - `useCapture`(可选):`true`(捕获阶段处理)/ `false`(冒泡阶段处理,默认值) #### 三、使用示例 1. **基础点击事件** ```html <button id="myBtn">点击我</button> <script> document.getElementById("myBtn").addEventListener("click", function() { alert("按钮被点击!"); }); </script> ``` 2. **同一元素绑定多个事件** ```javascript const btn = document.querySelector("#submitBtn"); // 点击事件 btn.addEventListener("click", () => console.log("点击提交")); // 鼠标悬停事件 btn.addEventListener("mouseover", () => btn.style.backgroundColor = "yellow"); ``` 3. **事件对象(Event Object)** 回调函数自动接收事件对象参数,包含事件信息: ```javascript document.addEventListener("keydown", (event) => { console.log(`按下的键:${event.key}`); // 输出按键名称 }); ``` #### 四、进阶技巧 1. **移除事件监听器** 需使用**具名函数**(匿名函数无法移除): ```javascript function handleClick() { console.log("执行一次"); } element.addEventListener("click", handleClick); element.removeEventListener("click", handleClick); // 成功移除 ``` 2. **事件委托(Event Delegation)** 通过父元素监听子元素事件,适合**动态生成的内容**: ```javascript document.getElementById("list").addEventListener("click", (event) => { if (event.target.tagName === "LI") { console.log(`点击了列表项:${event.target.textContent}`); } }); ``` 3. **控制事件传播** - `event.stopPropagation()`:阻止事件冒泡 - `event.preventDefault()`:阻止默认行为(如链接跳转) #### 五、兼容性处理 现代浏览器均支持 `addEventListener()`,旧版 IE(IE8-)需使用 `attachEvent()`: ```javascript if (element.addEventListener) { element.addEventListener("click", callback); // 标准写法 } else if (element.attachEvent) { element.attachEvent("onclick", callback); // IE8及以下 } ``` #### 六、实际应用场景 1. **表单验证**:监听 `submit` 事件阻止非法提交 2. **动态内容交互**:为 AJAX 加载的元素绑定事件 3. **页面性能优化**:通过事件委托减少监听器数量 4. **媒体控制**:监听视频 `timeupdate` 事件实现进度条同步 > 提示:使用 `{ once: true }` 参数可使事件**仅触发一次** > ```javascript > button.addEventListener("click", () => { > alert("仅显示一次"); > }, { once: true }); > ``` --- ### 相关问题 1. **事件捕获和冒泡阶段有什么区别?如何控制事件传播顺序?** 2. **如何为动态创建的 HTML 元素绑定事件监听器?** 3. **`addEventListener` 和 `onclick` 属性在事件处理上有何本质区别?** 4. **如何利用事件监听器实现防抖(Debounce)和节流(Throttle)?** [^1]: JavaScript HTML DOM EventListener 是创建交互式网页的关键工具,通过 addEventListener() 方法可以灵活地响应用户操作和系统事件。 [^2]: 在 JavaScript 中,我们可以通过使用 EventListener(事件监听器)来监听 HTML DOM(文档对象模型)中发生的事件,并执行相应的操作。 [^3]: EventListener(事件监听器)是 JavaScript 中的一个重要概念,用于监听和响应 HTML 文档中的事件。 [^4]: addEventListener方法比直接在HTML属性中设置事件处理程序更加灵活和强大。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值