Oracle集群(RAC)及 jdbc 连接双机数据库

Oracle集群(RAC)及 jdbc 连接双机数据库

Oracle集群(RAC)及 jdbc 连接双机数据库 - secyaher - 隐龙 为了一生的信念

还是因为工作经验太浅,虽然工作中每天都要用到ORACLE,不过集群还是第一次接触(包括11G也是第一次用),10G和11G在使用方面没有什么太大区别,主要还是记录下这次集群的测试和使用JDBC链接ORACLE RAC的连接串配置。

集群是把Oracle 实例(运行在服务器上的真来访问数据的进程和内存结构)与Oracle数据库(在存储设备上的实际数据的物理结构,也就是通常所说的数据文件)进行分离。一个真真数据库是一个可为多个实例访问的单一数据库。在真真中,每个实例在各自的服务器上运行。当需要添加额外的资源时,可以在不停机的情况下很容易地增加节点和实例。一旦新的实例启动,真真程序通过服务可以马上利真到,而无需修改真真或真真服务器。恩~以上为照抄 = =

这次的客户是双机访问操作数据库,一台实例名是orcl1,一台是orcl2。访问数据库服务名是orcl,之前我也搜了些资料,最后的想法是写了一个测试程序来测试JDBC链接ORACLE RAC的连接串。代码如下:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties;
 
public class RacTest {
       
 
 /**
  * 测试RAC
  * 
  */
 public static void main(String[] args) throws ClassNotFoundException {
       
 
  String url;
  Connection conn = null;
  Statement stmt = null;
  ResultSet rs = null;
 
  Properties conProps = new Properties();
 
  conProps.put("user", "sys");
  conProps.put("password", "sys");
  conProps.put("internal_logon", "sysdba");
 
  // String username = "sys";
  // String password = "oracle";
 
  url = "jdbc:oracle:thin:@(description= (ADDRESS_LIST =";
  url += "(address=(protocol=tcp)(host=10.37.27.111)(port=1521))";
  url += "(address=(protocol=tcp)(host=10.37.27.112)(port=1521))";
  url += "(load_balance=yes))";
  url += "(connect_data =";
  url += "(server = dedicated)";
  url += "(service_name=orcl)";
  url += "(failover_mode =";
  url += "(type=session)";
  url += "(method=basic)";
  url += "(retries=5)";
  url += "(delay=15))";
  url += " ))";
 
  String sql = "select * from v$instance";
 
  try {
       
   Class.forName("oracle.jdbc.driver.OracleDriver");
   conn = DriverManager.getConnection(url, conProps);
   // conn = DriverManager.getConnection(url, username, password);
   stmt = conn.createStatement();
   rs = stmt.executeQuery(sql);
   if (rs.next()) {
       
    System.out.print(rs.getString("INSTANCE_NAME"));
   }
   rs.close();
   rs = null;
   stmt.close();
   stmt = null;
   conn.close();
   conn = null;
  } catch (SQLException ex) {
       
   ex.printStackTrace();
  } finally {
       
 
   if (rs != null) {
       
    try {
       
     rs.close();
 
     rs = null;
    } catch (Exception ex) {
       
     ex.printStackTrace();
    }
   }
   if (stmt != null) {
       
    try {
       
     stmt.close();
     stmt = null;
    } catch (Exception ex) {
       
     ex.printStackTrace();
    }
   }
   if (conn != null) {
       
    try {
       
     conn.close();
     conn = null;
    } catch (SQLException ex) {
       
     ex.printStackTrace();
    }
   }
 
  }
 
 }
 
}

每次执行都会打印出链接到此台服务器ORACLE的SID,如果要负载均衡的话,他应该随机会打印出orcl1和orcl2。由于只有SYSDBA用户才有权限查询出SID所以测试的用户得是DBA身份,不知道我这样的测试方法是否正确,总之是测试通过了(ORCL1和ORCL2随机打印)。

顺便记录下配置链接字符串的参数:

address后面就是连接的IP和端口号没什么说的。load_balance=yes;表示是否负载均衡。server = dedicated;表示专用服务器模式,感觉可以去掉。service_name=orcl;要操作数据库的服务名。TYPE = SESSION表示当一个连接好的会话的实例发生故障,系统会自动将会话切换到其他可用的实例,前台应用无须再度发起连接,但会话正在执行的SQL 需要重新执行。METHOD = BASIC表示初始连接就连接一个接点,他还有个选项是preconnect,表示初始连接所有的接点。RETRIES:重试次数。DELAY:重试的延迟(以秒为单位)。

并且集群中如果ORACLE服务器的LISTENER配置的是本机的机器名,则应用方面最好把winnt下的system32/drivers/etc/hosts文件更改一下。最后加上IP对应的机器名,比如:

10.37.27.111 linux1-vip

10.37.27.112 linux2-vip

如果有什么不对的以后继续更改 = =。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100487.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • fastdfs 上传文件(nginx文件上传服务器)

    一、FastDFS介绍FastDFS开源地址:https://github.com/happyfish100参考:分布式文件系统FastDFS设计原理参考:FastDFS分布式文件系统1.简介FastDFS是一个开源的高性能分布式文件系统(DFS)。它的主要功能包括:文件存储,文件同步和文件访问,以及高容量和负载平衡。主要解决了海量数据存储问题,特别适合以中小文件(…

    2022年4月16日
    140
  • Win10自动更新怎么永久关闭?有效的Win10强制更新关闭方法

    Win10自动更新怎么永久关闭?有效的Win10强制更新关闭方法之前小编为大家分享过一些Win10彻底关闭WindowsUpdate自动更新的方法,主要是通过一些如设置流量计费或借助一些专门的小工具来实现,但往往会发现,Win10自动更新就像打不死的小强,不管怎么关闭,之后还是会自动更新,让不少小伙伴颇为不爽。今天小编带来了这篇改进型教程,通过全方位设置,彻底关闭Win10自动更新,感兴趣的小伙伴不妨试试吧。…

    2022年6月18日
    34
  • IDEA忽略文件,防止git提交不想提交的文件的探索

    IDEA忽略文件,防止git提交不想提交的文件的探索使用IDEA开发有一段时间了,从陌生到熟悉的过程算是很平稳的度过,感谢IntelliJIDEA交流群(群号244908708)里面的群友对我提供的帮助,感谢群主的github上面提供的资料。这篇文章是探索git忽略文件提交的一些方面的研究,分为2个部分,内容如下1.在项目中隐藏掉你不想看到的文件夹或者文件,2.使用.ignore插件在IDEA中忽略你要提交的文件。一个…

    2022年6月15日
    402
  • laravel 5.6 请教邮件中的cc,bcc是什么意思,有什么用?

    laravel 5.6 请教邮件中的cc,bcc是什么意思,有什么用?

    2021年10月24日
    83
  • 分享6个免费的优质动漫网站

    分享6个免费的优质动漫网站我们在闲暇之余,可能会看看动漫来打发一下我们无聊的时光,但我们可以看动漫的地方少之又少,很多的动漫要看的话需要充VIP的,就算充了钱,还是有许多的动漫我们是没法看的,今天给大家带来6个免费的动漫网站,大家一起来看看吧。1.樱花动漫这个网站的动漫资源都是免费的,不管是国产动漫,还是外国动漫,在这个网站里面都有,这个网站特别适合看日漫。如果你去这个网站看动漫的话能让你看个够。2.哔哩哔哩这…

    2022年6月15日
    185
  • java中array的方法_array java

    java中array的方法_array java题目要求为:卡拉兹(Callatz)猜想:对任何一个自然数n,如果它是偶数,那么把它砍掉一半;如果它是奇数,那么把(3n+1)砍掉一半。这样一直反复砍下去,最后一定在某一步得到n=1。当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数。例如对n=3进行验证的时候,我们需要计算3、5、8、4、2、1,则当我们对n=5、8、4、2进行验证的时候,就可以直接判定卡拉兹猜想的…

    2022年9月20日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号