我们有一对Oracle服务器,它们被设置为集群中的节点(如果我的术语已经过时,我会道歉).在我的tnsnames.ora文件中,我们有一个看起来像的条目
EXAMPLE.GOV =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 1.2.3.4)(PORT = 1521))
(ADDRESS = (PROTOCOL = TCP)(HOST = 1.2.3.5)(PORT = 1521))
(LOAD_BALANCE = yes)
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = example.gov)
)
)
当我连接使用tnsnames.ora文件的程序时,这可行.但是,我也有一个使用oracle.jdbc.pool.OracleDataSource类建立连接的Java程序
public static Connection connect() throws Exception {
OracleDataSource ods = new OracleDataSource();
ods.setDriverType("thin");
ods.setServerName("1.2.3.4");
ods.setDatabaseName("example");
ods.setPortNumber(1521);
ods.setUser("scott");
ods.setPassword("tiger");
return ods.getConnection();
}
它只是直接连接到其中一个节点.我想改为使用负载均衡的tnsnames.ora方法,它使用负载均衡或任何连接到其中一个节点的方式,这样如果其中一个节点关闭,那么它将自动连接到另一个节点.
由于我只有两个节点,我可以轻松地尝试打开与第一个节点的连接,然后如果不起作用则打开与第二个节点的连接.但是,我想知道是否有更正确的方法来做到这一点.
我看到有一个setTNSEntryName参数,但由于我的tnsnames.ora位于非标准位置,我需要设置TNS_ADMIN环境变量,我不确定我甚至可以在Java中做什么.我也不确定这在任何情况下都会有效.
有谁知道如何从Java程序连接到Oracle节点集群?