领导给了一串连接串给我,如下:
PERAC =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 131.197.17.137)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = 131.197.17.138)(PORT = 1521))
(LOAD_BALANCE = yes)
(FAILOVER = ON)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = pe)
(FAILOVER_MODE =
(TYPE = SELECT)
(METHOD = BASIC)
(RETRIES=180)
(DELAY=5)
)
)
)
要我在程序配置好这一串连接,其实很简单。只需要把上面这一串放在以前只放置一条url连接的url标签就可以了。以前配置的时候只是一个地址。现在有两个,需要用上面那一串。
配置c3p0没问题,如下:
<property name="connection.url">jdbc:oracle:thin:@(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 131.197.17.137)(PORT = 1521))(ADDRESS = (PROTOCOL = TCP)(HOST = 131.197.17.138)(PORT = 1521))(LOAD_BALANCE = yes)(CONNECT_DATA =(SERVER = DEDICATED)(SERVICE_NAME = pe)))</property>
但有些操作用到的是Spring的jdbcTemplate来做的。如果我想c3p0一样把两个地址写在url标签里。会报错,如下:
Connection refused(DESCRIPTION=(ERR=1153)(VSNNUM=169870336)(ERROR_STACK=(ERROR=(CODE=1153)(EMFI=4)(ARGS='(ADDRESS=(PROTOCOL=TCP)(HOST=131.197.17.138)(PORT=1521))'))(ERROR=(CODE=305)(EMFI=1))))
刚开始我以为是138这个机器连不上,因为它提示的是138,于是我只用了137的机器去连接,结果还是报这个错,最后换成了138去连,放而没问题了!不过不能同时写137和138,其实只用到了一个地址。哪怕写一个地址的时候。也要这样写:
<value>jdbc:oracle:thin:@(DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = 131.197.17.138)(PORT = 1521))(LOAD_BALANCE = yes)(CONNECT_DATA = (SERVICE_NAME=pe)))</value>
不能简单的url+端口+sid,不然会报错:
Could not get JDBC Connection; nested exception is java.sql.SQLException: Io 异常: Connection refused(DESCRIPTION=(TMP=)(VSNNUM=169870336)(ERR=12505)(ERROR_STACK=(ERROR=(CODE=12505)(EMFI=4))))
我还在尝试,如何才能在spring的jdbcTemplate配置双地址。难道是是因为org.springframework.jdbc.datasource.DriverManagerDataSource有关?要改成连接池?我尝试下吧!反正以上是可以用了。
最后问题解决了!其实直接把连接串写在url标签就可以了。只需要你的数据库驱动是最新的!这个很重要。我之前有的是class12.jar,用这个驱动的话很不稳定,时好时坏,于是换了ojdbc.jar,好家伙!怎么折腾都没事!问题解决!
以下是网上转载的,留档学习:
顺便记录下配置链接字符串的参数:
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
分享到:
相关推荐
数据库连接池jar包,包含c3p0、druidjar包和依赖jar包,c3p0通过配置文件xml或者properties读取连接对象 druid通过properties读取连接,使用springJDBC JdbcTempalte简化sql操作
使用Spring的JdbcTemplate调用Oracle的存储过程
Spring JdbcTemplate调用Oracle存储过程输出游标结果集实现增删改查
SpringMvc+JdbcTemplate+oracle的小项目实例,自己也是初学java,摸索着做的一个登陆,注册小程序,带服务器和客户端验证.
Spring jdbcTemplate调用Oracle存储过程返回List集合
C3P0、Druid、JDBCTemplate需要的jar包
JDBC整合c3p0数据库连接池 解决Too many connections错误 连接池是创建和管理一个连接的缓冲池的技术,这些连接准备好被任何需要它们的线程使用。博客地址 ...
配制Spring事务和JdbcTemplate使用 配制Spring事务和JdbcTemplate使用
spring无web.xml的jdbctemplate配置
Oracle 数据源配置 execute 调用无返回值存储过程 execute 调用单个返回值存储过程 execute 调用返回结果集存储过程 call 方法调用存储过程 前 言 1、关于 JdbcTemplate 的介绍、pom 依赖、DI 注入可以参考《Spring...
配置JdbcTemplate,源代码,配置详解
1. Oracle 存储过程分页 2. Java 调用 Oracle 存储过程 3. Flex 分页
此资源包含了三个常用的连接池(C3P0、Druid、JDBCTemplete),供大家下载使用。
https://blog.csdn.net/u012081441/article/details/80746538
springMVC配置jdbcTemplate连接oracle数据库 所需要的jar包
本资源包含了两个子项目,分别进行了springboot+jpa+jdbcTemplate的多数据源独立事务配置和jta分布式事务配置,并针对不同的情况编写了事务配置测试接口,还演示了JPA的domain一对多自动生成数据库表且不生成数据库...
SSH笔记-Spring JdbcTemplate,使用JdbcTemplate对数据库进行操作,使用具名参数和JDBC模板,简化操作
JDBCTemplate的使用很简单 只要在ApplicationContext文件里定义一个jdbcTemplate节点 POJO获得注入后可以直接执行操作 不需要继承什么基类
sprint boot JdbcTemplate MyBatis JPA多数据源配置xmind
JdbcTemplate 调用存储过程