`

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对应的监听

 

分享到:
评论

相关推荐

    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监听器维护管理v1.1

    3.2修改local_listener参数注册 17 4、静态注册 17 5、查看注册类型 18 五、监听日志基本操作 19 1、监听器日志特性 19 2、查看监听日志配置 19 3、关闭监听日志 21 4、保存配置 21 5、确认配置生效 21 6、确认配置...

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

    客户端进行连接的时候,系统不定期出现ora-12520,ora-12516的连接问题, 问题解决方案建议: 1、增加process和session的连接数。 2、检查连接的应用,是不是有没有释放...3、将修改参数local_listener中的vip为scan_ip。

    VMWARE虚拟机下安装Oracle 11g_RAC

    RAC概述: Oracle 11gR2 引入了很多新特性, Oracle 11...Local listener 中去,由 local 的 listener 提供服务给客户 端。 此外,安装 GRID 的过程也简化了很多,内核参数的设置可保证安装的最低设置,直接 使用 ASM 存储,

    操作系统重装后oracle数据库的恢复

    a、配置参数的恢复,oracle_home\network\admin\listener.ora,检查本地机器名是否有变化,以确定监听参数中监听地址项是否需要修伽。 b、本地访问服务名tnsnames.ora的配置,同样需要检查机器名或ip地址是否有...

    如何改变Oracle10g的端口

    监听程序参数文件 D:\oracle\product\10.2.0\db_1\network\admin\listener.o ra 监听程序日志文件 D:\oracle\product\10.2.0\db_1\network\log\listener.log 监听端点概要... (DESCRIPTION=(ADDRESS=(PROTOCOL=ipc)...

    java微信公众号MVC开发框架

    本例中微信方法并没有设置参数,实际可以灵活设置参数,例如我们可以在方法中设置HttpServletRequest request,HttpServletResponse response,InMessage in, WeixinContext context等参数,这部分内容也放在使用...

    xUtils3 demo

    方法参数形式必须和type对应的Listener接口一致. * 4. 注解参数value支持数组: value={id1, id2, id3} * 5. 其它参数说明见{@link org.xutils.event.annotation.Event}类的说明. **/ @Event(value = R.id.btn_...

    ssh(structs,spring,hibernate)框架中的上传下载

    9. <ref local="nativeJdbcExtractor"/> 10. 11. 12. … 13. </beans>  首先,必须定义一个能够从连接池中抽取出本地数据库JDBC对象(如OracleConnection,OracleResultSet等)的抽取器:...

    Java™ Servlet 规范.

    1.6.1 监听器(Listener)顺序 ...............................................................................................................14 1.6.2 注解处理 .............................................

    Servlet3.1规范(最终版) PDF

    1.6.1 监听器(Listener)顺序 ...............................................................................................................14 1.6.2 注解处理 ...............................................

Global site tag (gtag.js) - Google Analytics