数据库管理-第352期 从需求看懂Oracle RAC多租户环境的Service(20250729)

数据库管理352期 2025-07-29

数据库管理-第352期 从需求看懂Oracle RAC多租户环境的Service(20250729)

text 复制代码
作者:胖头鱼的鱼缸(尹海文)
Oracle ACE Pro: Database
PostgreSQL ACE Partner

10年数据库行业经验
拥有OCM 11g/12c/19c、MySQL 8.0 OCP、Exadata、CDP等认证
墨天轮MVP,ITPUB认证专家
圈内拥有"总监"称号,非著名社恐(社交恐怖分子)

公众号:胖头鱼的鱼缸
CSDN:胖头鱼的鱼缸(尹海文)
墨天轮:胖头鱼的鱼缸
ITPUB:yhw1809
IFClub:胖头鱼的鱼缸
除授权转载并标明出处外,均为"非法"抄袭

在最早写的几篇文章中,我写过在Oracle RAC多租户环境下如何配置Service,由于是刚刚开始写,写的不咋滴,回头看我感觉自己都有点看不明白,今天花一篇文章用实际需求(案例)来讲清楚RAC下常用的Service配置。

1 环境说明

这里说一下基本环境:

  • 版本为19c
  • 4节点RAC
  • 数据库名称问racdb
  • 实例名分别为racdb1、racdb2、racdb3、racdb4
  • rac1-3用于生产,rac4用于基本测试

2 srvctl

在Oracle RAC多租户环境下配置Service,我们需要在oracle用户下使用srvctl命令来添加Service,可以通过下面方式来获取命令帮助:

bash 复制代码
srvctl add service -help

3 需求与解决

3.1 需要一个测试库Service

创建一个运行在racdb4实例上的测试PDB的Service

PDB名称 Service名称 常驻实例 可用实例
pdb_test testdb racdb4 -
bash 复制代码
srvctl add service -db racdb -pdb pdb_test -s testdb -preferred racdb4
srvctl start service -db racdb -s testdb
# 可以通过下面命令来查看Service运行与配置情况
srvctl config service -db racdb -s testdb

这时候可以通过下面的连接字符串访问到对应数据库:

bash 复制代码
scan_ip:1521/testdb

3.2 创建生产数据库Service

创建一个常驻运行在racdb1实例上的数据库Service,在racdb1出现异常时,racdb2可以接管该Service

PDB名称 Service名称 常驻实例 可用实例
pdb_test db1 racdb1 racdb2
bash 复制代码
srvctl add service -db racdb -pdb pdb_test -s db1 -preferred racdb1 -available racdb2
srvctl start service -db racdb -s db1

这时候可以通过下面的连接字符串访问到对应数据库:

bash 复制代码
scan_ip:1521/db1
在此基础上增加session级别失败转移

常驻实例出现异常时,整个会话会被转移到可用实例执行

bash 复制代码
srvctl modify service -db racdb -s db1 -failovertype session
再加上失败转移恢复后回切至原实例

racdb1出现异常恢复后,运行在racdb2上的Service将回到racdb1上运行

bash 复制代码
srvctl modify service -db racdb -s db1 -failback YES
调整为TRANSACTION级别失败转移

常驻实例出现异常时,整个事务会被转移到可用实例执行

bash 复制代码
srvctl modify service -db racdb -s db1 -failovertype transaction -commit_outcome true
添加一个常驻实例
bash 复制代码
srvctl modify service -db racdb -s db1 -modifyconfig -preferred racdb1,racdb3  -available racdb2

修改完成后,服务不会在新添加的实例上运行,需要手工启动。

3.3 创建一个备库Service

默认创建的Service的角色是PRIMARY。在ADG环境中,当主备角色切换后角色变更为PHYSICAL_STANDBY启动的Service

PDB名称 Service名称 常驻实例 可用实例
pdb_test db1_ro racdb1 racdb2
bash 复制代码
srvctl add service -db racdb -pdb pdb_test -s db1_ro -preferred racdb1 -available racdb2 -role physical_standby

当数据库以PHYSICAL_STANDBY角色启动后可以通过下面的连接字符串访问到对应数据库:

bash 复制代码
scan_ip:1521/db1_ro

总结

本期通过实际需求与案例介绍了Oracle RAC多租户环境的Service。

老规矩知道写了些啥。

相关推荐
小菜同学爱学习17 分钟前
第一章 初识达梦数据库:基础认知与环境准备
数据库·达梦
zhoutongsheng20 分钟前
如何解决ORA-01078参数文件错误_pfile与spfile互相创建恢复
jvm·数据库·python
m0_7162550022 分钟前
批处理一道例题+答案解析+批处理知识点总结 | 批处理高频易错场景 + 正确写法对照表
数据库·oracle
2401_8242226924 分钟前
HTML怎么标注字数限制提示_HTML实时字数统计占位【详解】
jvm·数据库·python
稀饭过霍39 分钟前
数据类型【TINYINT、SMALLINT、INT、BIGINT、decimal(18,2)】表示意思
数据库
俺不要写代码43 分钟前
数据库:DML
数据库·oracle
这个DBA有点耶1 小时前
两张百万级大表JOIN跑崩了?试试这3招
数据库·代码规范
IntMainJhy1 小时前
「Flutter三方库sqflite的鸿蒙化适配与实战指南:从入门到踩坑的本地数据库开发全记录」
数据库·flutter·华为·信息可视化·数据库开发·harmonyos
counting money1 小时前
Spring框架基础(依赖注入-全注解形式)
java·数据库·spring
计算机安禾1 小时前
【Linux从入门到精通】第33篇:数据库MySQL/MariaDB安装与基础调优
linux·数据库·mysql