listener之一二(二)
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、如果想远程启动数据库,需要通过静态注册。