网站首页 > 技术文章 正文
概述
动态服务是实例在服务器上启动并运行时向侦听器注册的代表,而静态服务(SID_LIST_LISTENER)可用于服务外部连接,无论是否在服务器上运行实例,连接非常有用到空闲或 NOMOUNT 数据库。
根据Oracle 19c Advanced Features of Oracle Net Services,静态服务的用例可以是以下任何一种:
- 外部过程调用
- Oracle 异构服务
- Oracle Data Guard
- 从 Oracle Enterprise Manager Cloud Control 以外的工具远程启动数据库
- 与早于 Oracle8i 版本 2 (8.1) 的 Oracle 数据库的连接
1.添加单个静态服务
启用静态服务注册功能的配置非常简单,只需在监听器配置文件中添加一个名为SID_LIST_LISTENER的条目,该文件通常位于$ORACLE_HOME/network/admin/listener.ora,然后重新启动监听器。
[oracle@test ~]$ vi $ORACLE_HOME/network/admin/listener.ora
...
SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1)
(SID_NAME=ORCL))
)
基本上,静态服务注册至少需要知道两项,ORACLE_HOME和ORACLE_SID。如您所见,我们在条目中提供了它们。
2.添加多个静态服务
对于更多ORACLE_SID,您可以像这样将SID_LIST附加到条目中。
[oracle@test ~]$ vi $ORACLE_HOME/network/admin/listener.ora
...
SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1)
(SID_NAME=ORCL))
(SID_DESC=
(ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1)
(SID_NAME=SMALLDB))
)
3. 使用 GLOBAL_DBNAME
对于那些DB_DOMAIN不为空的数据库,您应该在SID_LIST中添加更多信息GLOBAL_DBNAME。
[oracle@test ~]$ vi $ORACLE_HOME/network/admin/listener.ora
...
SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1)
(SID_NAME=ORCL))
(GLOBAL_DBNAME=orcl.example.com)
)
GLOBAL_DBNAME的格式如下:
<DB_UNIQUE_NAME>.<DB_DOMAIN>
在上述情况下,数据库的DB_DOMAIN是example.com。请注意,如果您的DB_DOMAIN为空,则不必添加它。不要忘记重新启动监听器以立即生效。
4. Data Guard Broker 的静态服务
您必须为数据保护代理添加一个特殊的静态服务<DB_UNIQUE_NAME>_DGMGRL.<DB_DOMAIN>以启用需要重新启动实例而无需手动干预的代理操作,例如通过switchover在主数据库和备用数据库之间进行角色转换。
[oracle@test ~]$ vi $ORACLE_HOME/network/admin/listener.ora
...
SID_LIST_LISTENER=
(SID_LIST=
(SID_DESC=
(ORACLE_HOME=/u01/app/oracle/product/11.2.0/dbhome_1)
(SID_NAME=ORCL))
(GLOBAL_DBNAME=ORCL_DGMGRL)
)
请注意,如果您的DB_DOMAIN为空,则不必添加它。所有服务名称最好大写。
服务名称的状态
让我们看看他们在监听器中的状态。
[oracle@test ~]$ lsnrctl status
...
Services Summary...
Service "ORCL" has 2 instance(s).
Instance "ORCL", status UNKNOWN, has 1 handler(s) for this service...
Instance "ORCL", status READY, has 1 handler(s) for this service...
Service "ORCLXDB" has 1 instance(s).
Instance "ORCL", status READY, has 1 handler(s) for this service...
The command completed successfully
静态服务ORCL的状态被标记为UNKNOWN,而动态服务是READY,这意味着实例确实存在并准备好服务。
猜你喜欢
- 2024-10-23 「JavaWeb基础」JDBC用户登录注册(修订版)
- 2024-10-23 一文看懂django应如何将应用注册到项目
- 2024-10-23 Oracle Goldengate高可用配置 oracle的高可用
- 2024-10-23 CentOS7环境下实现SAS与oracle的交互
- 2024-10-23 Oracle-Oracle DB、监听和oem开机启动
- 2024-10-23 安装jdk1.8并配置系统变量 jdk如何安装配置变量
- 2024-10-23 手把手教你:使用Oracle AutoML进行预测(实战教程)
- 2024-10-23 7.14 在 vCenter Server 注册虚拟机理论与实践
- 2024-10-23 在Oracle Cloud Infrastructure上部署Ruby on Rails:高效实践指南
- 2024-10-23 如何升级oracle数据库安全补丁 oracle数据库升级版本
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)