oracle动态注册和静态注册,oracle监听器动态注册于静态注册的区别

1, oracle 10g 用netca方式创建的都默认为动态注册方式

2,若是想改成静态注册的方式则在listener.ora 中加入以下内容便可

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(SID_NAME = PLSExtProc)

(ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1)

(PROGRAM = extproc)

)

(SID_DESC =

(SID_NAME = JEFF )

(ORACLE_HOME = /u01/app/oracle/product/10.2.0/db_1) --就这一段

(GLOBAL_DBNAME = jeff)

)

) 数据库

LISTENER =

(DESCRIPTION_LIST =

(DESCRIPTION =

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

(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))

)

)

3,二者的区别

即静态注册,listener不知道实例的状态,只有在进程经过其链接数据库时才能知道,若是你想使用远程管理数据库就使用静态监听

动态注册:listener实时的都知道实例的状态,数据库在关闭的时候会动态的从listener中注销,因此远程管理数据库的启动和中止就不行了。

4,如何判断是静态注册仍是动态注册

(1) 能够经过配置文件判断 oracle

动态注册 app

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(PROGRAM = extproc)

(SID_NAME = PLSExtProc)

(ORACLE_HOME = D:\oradata\orcl)

)

) tcp

静态注册 this

SID_LIST_LISTENER =

(SID_LIST =

(SID_DESC =

(PROGRAM = extproc)

(SID_NAME = PLSExtProc)

(ORACLE_HOME = D:\oradata\orcl)

)

(SID_DESC =

(GLOBAL_DBNAME = orcl)

(ORACLE_HOME = D:\oradata\orcl)

(SID_NAME = ORCL)

)

(SID_DESC =

(GLOBAL_DBNAME = orcl1)

(ORACLE_HOME = D:\oradata\orcl)

(SID_NAME = ORCL)

)

) spa

经过查看虽然能够大体看出,可是这种方法并不能和明确的现实数据库在运行时的实际状况 进程

(2) lsnrclt status

----静态注册是这样的 都是unknow

Services Summary...

Service "PLSExtProc" has 1 instance(s).

Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...

Service "jeff" has 1 instance(s).

Instance "JEFF", status UNKNOWN, has 1 handler(s) for this service...

The command completed successfully ip

-----动态注册是这样的

Services Summary...

Service "JEFF" has 1 instance(s).

Instance "JEFF", status READY, has 1 handler(s) for this service...

Service "JEFFXDB" has 1 instance(s).

Instance "JEFF", status READY, has 1 handler(s) for this service...

Service "JEFF_XPT" has 1 instance(s).

Instance "JEFF", status READY, has 1 handler(s) for this service...

Service "PLSExtProc" has 1 instance(s).

Instance "PLSExtProc", status UNKNOWN, has 1 handler(s) for this service...

The command completed successfully tls

3,有时候会碰到即便listener起来也不能链接到数据库的状况 。会报一个ORA-12514 , 配置

运行lsnrctls status 是这个样子的 ,说明没有服务没有注册进来

Listening Endpoints Summary...

(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=r1)(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...

The command completed successfully

解决方法:

alter system register; ---手动将服务注册到listener中

4,若是我想使用动态注册,可是又不想使用1521端口怎么办

这个时候咱们就要用到 local_listener这个参数了,当你使用的是其余端口好比说是1522端口,那么只要配置这个参数就ok了。

SQL> alter system set local_listener='(DESCRIPTION =

2 (ADDRESS = (PROTOCOL = TCP)(HOST = xys)(PORT = 1522))

3 )';

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值