oracle rac

1、app连接oracle rac集群

连接到 Oracle RAC(Real Application Clusters)的多种配置方式
1. 使用 JDBC 连接字符串:

使用 JDBC 连接字符串是连接 Oracle RAC 的常见方式。连接字符串的格式如下:

复制代码
jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(LOAD_BALANCE=on)(FAILOVER=on)(ADDRESS=(PROTOCOL=TCP)(HOST=<hostname1>)(PORT=<port1>))(ADDRESS=(PROTOCOL=TCP)(HOST=<hostname2>)(PORT=<port2>))(ADDRESS=(PROTOCOL=TCP)(HOST=<hostname3>)(PORT=<port3>)))(CONNECT_DATA=(SERVICE_NAME=<service_name>)(FAILOVER_MODE=(TYPE=select)(METHOD=basic))))

<hostname1>, <hostname2>, <hostname3>是 Oracle RAC 集群中不同节点的主机名。

<port1>,<port2>, <port3>是 Oracle 监听器的端口号。

<service_name> 是 RAC 数据库的服务名称。

2. 使用 TNSNAMES.ORA 文件:

在客户端计算机上配置 TNSAMES.ORA 文件,该文件包含与 Oracle RAC 集群的连接信息。在文件中定义数据库连接别名和连接描述符。然后,在客户端应用程序中使用别名作为数据库连接的目标。

复制代码
ORACLERAC =
     (DESCRIPTION =
       (ADDRESS_LIST =
         (LOAD_BALANCEon)
         (FAILOVER=on)
         (ADDRESS = (PROTOCOL = TCP)(HOST = <hostname1>)(PORT = <port1>))
         (ADDRESS = (PROTOCOL = TCP)(HOST = <hostname2>)(PORT = <port2>))
         (ADDRESS = (PROTOCOL = TCP)(HOST = <hostname3>)(PORT = <port3>))
       )
       (CONNECT_DATA =
         (SERVICE_NAME = <service_name>)
         (FAILOVER_MODE =
           (TYPE=select)
           (METHOD=basic)
         )
       )
     )

3. 使用扫描监听器(SCAN Listener):

扫描监听器是 Oracle RAC 中的虚拟监听器,用于提供集群级别的入口。通过使用扫描监听器,客户端应用程序可以连接到 Oracle RAC 集群,而不需要了解底层的详细信息。扫描监听器会根据负载均衡策略将连接转发到适当的节点。

复制代码
jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=<scan_name>)(PORT=<port>)))(CONNECT_DATA=(SERVICE_NAME=<service_name>)))

<scan_name> 是扫描监听器的名称,它提供了连接到集群的虚拟化服务名称。

<port> 是监听器的端口号。

<service_name>是 RAC 数据库的服务名称,用于标识需要连接的数据库。

4、java.properties

复制代码
# 数据库连接信息
spring.datasource.url=jdbc:oracle:thin:@(description=(address_list= (address=(host=RAC1)(protocol=TCP)(port=1521))(address=(host=RAC2)(protocol=TCP)(port=1521)) (load_balance=yes)(failover=yes))(connect_data=(service_name=service_name)(server=DEDICATED)))
spring.datasource.username=your_username
spring.datasource.password=your_password
spring.datasource.driver-class-name=oracle.jdbc.OracleDriver

Oracle11g rac

复制代码
jdbc:oracle:thin:@(DESCRIPTION =(ADDRESS = (PROTOCOL = TCP)(HOST = 10.24.227.35)(PORT = 1521))(CONNECT_DATA = (SERVER = DEDICATED)(SERVICE_NAME = bjcrmdb)))

Oracle10g rac

复制代码
jdbc:oracle:thin:@(DESCRIPTION=(ADDRESS_LIST=(ADDRESS=(PROTOCOL=TCP)(HOST=ip)(PORT=1521))(ADDRESS=(PROTOCOL=TCP)(HOST=ip)(PORT=1521))(LOAD_BALANCE=yes)(FAILOVER=on))(CONNECT_DATA=(SERVICE_NAME=)))
相关推荐
程序定小飞16 分钟前
基于springboot的web的音乐网站开发与设计
java·前端·数据库·vue.js·spring boot·后端·spring
小灰灰搞电子25 分钟前
Rust 操作Sqlite数据库详细教程
数据库·rust·sqlite
IvorySQL39 分钟前
你真的知道你正在运行哪个 PostgreSQL吗?
数据库·postgresql
l1t1 小时前
利用DeepSeek采用hugeint转字符串函数完善luadbi-duckdb的decimal处理
数据库·lua·c·duckdb·deepseek
无敌最俊朗@1 小时前
Qt 开发终极坑点手册图表版本
数据库
yumgpkpm1 小时前
Doris 并入CMP7(类Cloudera CDP 7.3.1 404华为鲲鹏ARM版)的方案和实施源代码
大数据·oracle·sqlite·sqoop·milvus·cloudera
yumgpkpm1 小时前
Doris在CMP7(类Cloudera CDP 7 404版华为Kunpeng)启用 Kerberos部署Doris
大数据·hive·hadoop·python·oracle·flink·cloudera
老衲提灯找美女2 小时前
MySQL数据库基础操作:
数据库·mysql·oracle
轻舟客丶2 小时前
ORA-03113的解决方案
数据库·经验分享·笔记·oracle
ヾChen2 小时前
头歌MySQL——复杂查询
数据库·物联网·学习·mysql·头歌