`

local_listener参数作用

阅读更多

pmon只会动态注册port等于1521的监听,否则pmon不能动态注册listener,要想让pmon动态注册listener,需要设置local_listener参数。

LSNRCTL> start
启动tnslsnr: 请稍候...

TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Production
系统参数文件为e:oracleproduct10.2.0db_1networkadminlistener.ora
写入e:oracleproduct10.2.0db_1networkloglistener.log的日志信息
监听: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=xys)(PORT=1522)))

正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=xys)(PORT=1522)))
LISTENER 的 STATUS
------------------------
别名 LISTENER
版本 TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Produ
ction
启动日期 25-10月-2008 20:39:07
正常运行时间 0 天 0 小时 0 分 3 秒
跟踪级别 off
安全性 ON: Password or Local OS Authentication
SNMP OFF
监听程序参数文件 e:oracleproduct10.2.0db_1networkadminlistener.o
ra
监听程序日志文件 e:oracleproduct10.2.0db_1networkloglistener.log

监听端点概要...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=xys)(PORT=1522)))
服务摘要..
服务 "orcl" 包含 1 个例程。
例程 "orcl", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
服务 "test" 包含 1 个例程。
例程 "test", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
命令执行成功
LSNRCTL> status
正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=xys)(PORT=1522)))
LISTENER 的 STATUS
------------------------
别名 LISTENER
版本 TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Produ
ction
启动日期 25-10月-2008 20:39:07
正常运行时间 0 天 0 小时 0 分 6 秒
跟踪级别 off
安全性 ON: Password or Local OS Authentication
SNMP OFF
监听程序参数文件 e:oracleproduct10.2.0db_1networkadminlistener.o
ra
监听程序日志文件 e:oracleproduct10.2.0db_1networkloglistener.log

监听端点概要...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=xys)(PORT=1522)))
服务摘要..
服务 "orcl" 包含 1 个例程。
例程 "orcl", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
服务 "test" 包含 1 个例程。
例程 "test", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
命令执行成功

SQL> alter system register;    //手动注册

系统已更改。

SQL>
LSNRCTL> status
正在连接到 (DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=xys)(PORT=1522)))
LISTENER 的 STATUS
------------------------
别名 LISTENER
版本 TNSLSNR for 32-bit Windows: Version 10.2.0.1.0 - Produ
ction
启动日期 25-10月-2008 20:39:07
正常运行时间 0 天 0 小时 0 分 21 秒
跟踪级别 off
安全性 ON: Password or Local OS Authentication
SNMP OFF
监听程序参数文件 e:oracleproduct10.2.0db_1networkadminlistener.o
ra
监听程序日志文件 e:oracleproduct10.2.0db_1networkloglistener.log

监听端点概要...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=xys)(PORT=1522)))
服务摘要..
服务 "orcl" 包含 2 个例程。
例程 "orcl", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
例程 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
服务 "orcl_XPT" 包含 1 个例程。
例程 "orcl", 状态 READY, 包含此服务的 1 个处理程序...
服务 "test" 包含 1 个例程。
例程 "test", 状态 UNKNOWN, 包含此服务的 1 个处理程序...
命令执行成功

 

 

 

 

local_listener是用在当使用非默认的端口时,PMON进程能够进行动态注册。

我们可以这么设置该值形如,local_listener='(ADDRESS = (PROTOCOL = TCP)(HOST = hostname or ip)(PORT = 1521))'

这里说下该值的一个注意点:

先看下listener.ora的配置吧

SID_LIST_LISTENER =

(SID_LIST =

   (SID_DESC =

     (SID_NAME = PLSExtProc)

     (ORACLE_HOME = G:\oracle\product\10.2.0\db_2)

     (PROGRAM = extproc)

   )

   (SID_DESC =

     (GLOBAL_DBNAME = orcl1)

     (SID_NAME = orcl1)

     (ORACLE_HOME = G:\oracle\product\10.2.0\db_2)

     (PROGRAM = orcl1)

   )

)

 

LISTENER =

(DESCRIPTION_LIST =

   (DESCRIPTION =

     (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC1))

     (ADDRESS = (PROTOCOL = TCP)(HOST = fztxt)(PORT = 1521))

   )

)

 

TXT_LIS=

   (DESCRIPTION =

     (ADDRESS = (PROTOCOL = TCP)(HOST = fztxt)(PORT = 1525))

)

 

SID_LIST_TXT_LIS =

(SID_LIST =

   (SID_DESC =

     (SID_NAME = orcl1)

     (ORACLE_HOME = G:\oracle\product\10.2.0\db_2)

     (PROGRAM = orcl1)

   )

)

我们这么设置listener.ora,这样,就有了静态的监听了,包括listenertxt_lis,我们可以通过lsnrctl start txt_lis来启动这个监听,也可以通过lsnrctl status txt_lis来观察这个监听的状态。

当我们设置了listener.ora后,txt_lis还不能被客户端访问,那怎么使这个生效呢,这时我们就要PMON来进行动态注册,这就需要local_listener了。

Local_listener有两种设置:

1如果我们设置

Alter system set local_listener=’(ADDRESS = (PROTOCOL = TCP)(HOST = fztxt)(PORT = 1525))’。那么,我们只要alter system register;强制PMON注册,就可以实现动态注册了。

2、接下来,来讨论另外一个local_listener的设置:

Alter system set local_listener=txt_lis;

那么,PMON能识别出来吗?

答案是不能的,因为PMON不知道去哪里解析这个txt_lis

那有一种情况:如果我们是在数据宕机的时候修改的local_listener=txt_lis;那这时启动数据库,则会出现:

SQL> startup

ORA-00119: invalid specification for system parameter LOCAL_LISTENER

ORA-00132: syntax error or unresolved network name 'TXT_LIS'

这是因为:

要在服务器上的tnsnames.ora里做设置,来映射listener1

启动时它会去服务端的tnsnames.oratxt_lis的含义,找不到,解析不了,则会报ora-00132的错误。

那服务端的tnsnames.ora要怎么设置呢?

Txt_lis=(ADDRESS = (PROTOCOL = TCP)(HOST = fztxt)(PORT = 1525))

加上这个就OK了。

接下来我们再做另外的测试

SQL> alter system set local_listener='asdf';

alter system set local_listener='asdf'

*

1行出现错误:

ORA-02097:无法修改参数,因为指定的值无效

ORA-00119:系统参数LOCAL_LISTENER的说明无效

ORA-00132:语法错误或无法解析的网络名称'asdf'

说明:local_listener的值不能随便设置,要在listener.ora上有相应的标识

以上是local_listener的设置问题。

另外,就像上面批注里面说的,txt_lis注册的实例和服务跟默认的监听一样,那只要我们设置了alter system set local_listener=……

这时,我们listener status ,也就是默认的监听的状态,我们发现,动态监听没有了,剩下的静态监听

 

可以知道,默认的监听就只有静态监听了,动态监听都在等待local_listener所对应的监听了。PMON真是见风使舵啊。

更进一步,我们发现,只要我们成功设置了local_listener的值,包括实例和服务名不和默认监听一样,PMON都会在等待local_listener对应的监听

 

分享到:
评论

相关推荐

    Oracle12c启动问题解决说明

    ORA-00119错误是指系统参数LOCAL_LISTENER的设置无效,而ORA-00132错误是指语法错误或未解决的网络名'LISTENER_ORCL'。 二、解决方法 Oracle12c/oracle11g和oracle10g有一些区别,主要体现在spfile的位置不同。...

    Oracle9i的init.ora参数中文说明

    MTS_LISTENER_ADDRESS 参数可被指定为: (ADDRESS_LIST=(ADDRESS=(PROTOCOL=tcp)(PORT=5000)(HOST=zeus)) (ADDRESS=(PROTOCOL=decnet)(OBJECT=outa)(NODE=zeus)) 此参数在 8.1.3 版中已废弃。 值范围: TRUE | FALSE ...

    Oracle一个实例配置多个监听

    2. **设置`local_listener`**: 使用`ALTER SYSTEM`命令将`local_listener`参数设置为`ALL_LISTENER`。 ```sql ALTER SYSTEM SET LOCAL_LISTENER = ALL_LISTENER; ``` 3. **注册服务**: 使用`ALTER SYSTEM REGISTER`...

    Oracle12cRAC数据库 出现ora-12520, ora-12516

    - **修改参数**:打开每个实例的`spfile`文件,找到`local_listener`参数,并将其值更改为正确的SCAN_IP地址。 - **验证配置**:修改完成后,使用`show parameter local_listener`命令验证配置是否正确。 完成以上...

    Oracle 单一主机多个实例多个监听器配置

    ### 解决方案:设置local_listener参数 #### 1. LSNRCTL的帮助信息 `lsnrctl`是Oracle提供的命令行工具,用于管理监听器。它提供了各种操作,如启动、停止、显示状态等。通过`lsnrctl help`命令,用户可以查看所有...

    认识oracle中的sqlnet.ora tnsnames.ora listener.ora三个文件

    #### 三、`tnsnames.ora`与`listener.ora`的作用 1. **`tnsnames.ora`** - **位置**: 通常位于客户端的`$HOME/network/admin`目录中。 - **功能**: 用于配置数据库连接的别名,便于客户端通过简单的别名来连接...

    修改Oracle监听默认端口号1521的方法

    在修改了监听器配置后,我们需要更新数据库实例的`local_listener`参数。登录到数据库作为`sysdba`用户,运行`sqlplus / as sysdba`。通过`show parameter local_listener`查看当前`local_listener`的设置,如果为空...

    ORACLE数据库逐步解决ORA-12541、ORA-01034和ORA-27101、ORA-00119和ORA00132的过程

    ORA-00119和ORA-00132错误,提示为"invalid specification for system parameter LOCAL_LISTENER"和"syntax error or unresolved network name 'LISTENER_ORCL'",通常是因为初始化参数local_listener在init.ora文件...

    Oracle 最佳安全配置.pdf

    local_listener、O7_dictionary_accessibility、os_roles和remote_listener等参数应当根据实际情况适当设置,以确保数据库的访问控制和通信安全。此外,应禁用密码文件远程使用、远程操作系统认证和角色授权,并应...

    oracle中的sqlnet.ora+tnsnames.ora+listener.ora

    - `listener.ora`用于服务端,负责配置监听器参数,确保客户端能够成功连接到服务端。 这三个文件的正确配置对于实现Oracle客户端与服务端之间的稳定通信至关重要。理解它们的工作原理有助于快速诊断和解决问题。

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

    2. **动态注册服务到非默认监听器和非默认端口**:需要在`init.ora`中设置`local_listener`指向新的监听器名称或地址和端口,同时更新`tnsnames.ora`以解析新的监听器。 对于安全性考虑,应当定期检查`listener.ora...

    oracle遇到连接空闲例程

    - 示例格式:`local_listener=(address=(protocol=tcp)(host=your_host)(port=your_port))` #### 二、启动Oracle数据库 接下来,通过命令行工具启动Oracle数据库实例,并应用上述配置。 1. **打开命令提示符窗口...

    删除EM,强制结束EM进程后,启动数据库ORA-00119,ORA-00132报错的解决方法

    查看新创建的PFILE,找到LOCAL_LISTENER参数。如果它指向了旧的主机名或无法解析的网络名称(如'LISTENER_ORCL'),则需要修改为正确的值。正确的格式应为: ``` *.local_listener='(ADDRESS_LIST=(Address=...

    oracle客户端连接服务器常见问题

    错误信息:“TNS-01155: SID_LIST_LISTENER参数指定错误”。 **原因分析**: 此错误通常出现在`listener.ora`文件中,表示SID列表的配置存在问题。 **解决方法**: 修改`listener.ora`文件,确保`SID_LIST_...

    ORACLE数据库有关参数的理解

    - `local_listener`:此参数允许PMON进程将实例信息注册到本地监听器。如果未设置,实例将在默认端口1521上注册。只有当实例使用非标准端口时,才需要明确配置。 - `remote_listener`:在RAC环境中,此参数用于在...

    oracle注册.docx

    local_listener=(ADDRESS=(PROTOCOL=TCP)(HOST=localhost)(PORT=1521)) 五、实例恢复 在 Oracle 数据库中,实例恢复是指在数据库启动时自动执行的一系列操作,例如检查点、事务回滚等。实例恢复可以帮助数据库快速...

    listener.ora

    "listener.ora" 文件是 Oracle 数据库服务器配置中的一个重要组件,它定义了监听器(Listener)的配置信息,监听器负责处理客户端连接请求并转发到相应的数据库实例。在这个配置文件中,你可以设置多个监听器、定义...

    Oracle_TNS浅析.doc

    - 如果使用了其他通讯协议或监听端口,则需要通过`LOCAL_LISTENER`参数明确指定当前使用的监听器。 ##### 3. 多IP环境下的监听器配置 在具有多个IP地址的服务器上,可以通过配置监听器使其同时监听多个地址。例如...

Global site tag (gtag.js) - Google Analytics