Oracle9i以后,后台进程PMON自动在监听器中注册系统参数SERVICE_NAMES中定义的服务名,SERVICE_NAMES默认为DB_NAME+DOMAIN_NAME。监听配置文件listener.ora中可以不必监听的服务名。但是,当数据库处于关闭状态下,PMON进程没有启动,也就不会自动注册监听的实例名。所有就报错了。
如果在listener.ora文件中指定监听的实例名,则即使数据库处于关闭状态,仍然可以连接。
(SID_DESC =
(GLOBAL_DBNAME = ORCL)
(ORACLE_HOME = G:\oracle\product\10.2.0\db_1)
(SID_NAME = ORCL)
)
附:通过lsnrctl中输入set display verbose ,然后再通过命令servic查看,服务状态为read表示PMON自动注册的服务名,而UNKOMN则表示该服务是手工在listener.ora中配置的数据服务。
本文探讨了Oracle9i及以后版本中PMON进程如何自动注册服务名到监听器的过程,并解释了当数据库关闭时可能遇到的问题。此外,还介绍了如何通过手动配置listener.ora文件来解决这一问题。
8877

被折叠的 条评论
为什么被折叠?



