【GaussDB】GaussDB数据库开发设计之JDBC高可用性

1.设置负载均衡

步骤1、加载驱动,连接数据库,配置负载均衡

下载wget命令。

sql 复制代码
yum install -y wget

执行以下命令,下载GaussDB驱动包,并存放于 libs目录下。

sql 复制代码
mkdir -p /opt/expt/db/libs
cd /opt/expt/db/libs
wget https://edu-res.hc-cdn.cn/sharedata/hdinnovation/sandbox/20000743/GaussDB_driver.zip

解压GaussDB驱动包。

sql 复制代码
unzip GaussDB_driver.zip
cd GaussDB_driver/Distributed/Kylinv10_arm_64/
tar -xzvf GaussDB-Kernel_505.2.0_Kylin_64bit_Jdbc.tar.gz

步骤2、下载JDK软件包,并配置环境。

sql 复制代码
cd /root
wget https://edu-res.hc-cdn.cn/sharedata/hdinnovation/sandbox/20001943/jdk-8u442-linux-aarch64.tar.gz
tar -xzvf jdk-8u442-linux-aarch64.tar.gz
mv jdk1.8.0_442 /usr/lib/
ln -s /usr/lib/jdk1.8.0_442/bin/java /usr/local/bin/java
ln -s /usr/lib/jdk1.8.0_442/bin/javac /usr/local/bin/javac

步骤3、验证java运行命令是否就绪:

sql 复制代码
java -version

步骤4、验证javac运行命令是否就绪:

sql 复制代码
javac -version

步骤5、在指定目录创建test.java文件

sql 复制代码
mkdir -p /opt/expt/db/basic
cd /opt/expt/db/basic
touch test.java

步骤6、使用vim命令,将以下代码内容写入test.java文件中。输入结束后,使用":wq"保存退出vim编辑。

sql 复制代码
   String testQuery = "SELECT 1";

        try (Connection conn = DriverManager.getConnection(gs_url, gs_user, gs_passwd);
             Statement st = conn.createStatement();
             PreparedStatement pst = conn.prepareStatement(testQuery)) {

            for (int i = 0; i < 100; i++) {
                try {
                    ResultSet resultSet = pst.executeQuery();
                    if (resultSet.next()) {
                    }
                } catch (Exception e) {
                    System.err.println("\u7b2c " + (i + 1) + " \u6b21\u8fde\u63a5\u5931\u8d25: " + e.getMessage());
                }
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

代码中,用户名、密码、IP、端口号和数据库需修改为当前实际所使用的信息。

步骤7、进行编译:

sql 复制代码
javac test.java

编译完成后,会在当前目录下生编译成class数据文件及对应目录结构,参考如下:

步骤8、运行对应代码文件

sql 复制代码
java -cp $CLASSPATH:./*:/opt/expt/db/libs/GaussDB_driver/Distributed/Kylinv10_arm_64/* test

可以尝试配置负载均衡中的其他策略,观察不同输出结果。

将代码中DB_URL的内容修改为以下内容,其中增加了其他节点的IP:PORT信息,由于增加轮询策略,需要新增参数字符串。轮询策略可以修改为autoBalance=roundrobin;设置autoBalance为priorityn表示开启JDBC优先级负载均衡功能,将应用程序的多个连接首先均衡到url上配置的前n个中可用的CN数据库节点,当url上配置前n个节点全部不可用时,连接会随机分配到数据库集群中其他可用CN数据库节点;设置为shuffle表示开启JDBC随机负载均衡功能,将应用程序的多个连接随机均衡到数据库集群中的各个可用CN;设置为false,不开启JDBC负载均衡功能和优先级负载均衡功能,默认为不开启负载均衡。

2.设置读写分离

步骤1、修改参数targetServerType。

将参数修改为targetServerType=master,则尝试连接到url连接串中的主节点,如果找不到主节点将抛出异常(设置targetServerType=slave,则尝试连接到url连接串中的备节点,如果找不到备节点将抛出异常;设置targetServerType=preferSlave,则尝试连接到url连接串中的备节点,如果备节点不可用,将连接到主节点,否则抛出异常)。本实验只进行主库的连接。

sql 复制代码
--设置示例
--targetServerType=master;

再次使用vim命令,修改参数targetServerType。输入结束后,使用":wq"保存退出vim编辑。

sql 复制代码
vim test.java;

import java.sql.*;

public class test {
    private static String gs_user = "root";
    private static String gs_passwd = "password";
    private static String gs_url = "jdbc:gaussdb://xxx.xx.x.xxx:port,xxx.xx.x.xxx:port,xxx.xx.x.xxx:port/postgres?targetServerType=master";

public static void main(String[] args) {
        String testQuery = "SELECT 1";

        try (Connection conn = DriverManager.getConnection(gs_url, gs_user, gs_passwd);
             Statement st = conn.createStatement();
             PreparedStatement pst = conn.prepareStatement(testQuery)) {

            for (int i = 0; i < 100; i++) {
                try {
                    ResultSet resultSet = pst.executeQuery();
                    if (resultSet.next()) {
                    }
                } catch (Exception e) {
                    System.err.println("\u7b2c " + (i + 1) + " \u6b21\u8fde\u63a5\u5931\u8d25: " + e.getMessage());
                }
            }

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

步骤2、重新编译后运行程序。

sql 复制代码
javac test.java

java -cp $CLASSPATH:./*:/opt/expt/db/libs/GaussDB_driver/Distributed/Kylinv10_arm_64/* test

总结

本次主要是提供了GaussDB分布式数据库JDBC高可用性实验脚本~

相关推荐
小高不会迪斯科5 小时前
CMU 15445学习心得(二) 内存管理及数据移动--数据库系统如何玩转内存
数据库·oracle
e***8905 小时前
MySQL 8.0版本JDBC驱动Jar包
数据库·mysql·jar
l1t5 小时前
在wsl的python 3.14.3容器中使用databend包
开发语言·数据库·python·databend
失忆爆表症7 小时前
03_数据库配置指南:PostgreSQL 17 + pgvector 向量存储
数据库·postgresql
AI_56787 小时前
Excel数据透视表提速:Power Query预处理百万数据
数据库·excel
SQL必知必会8 小时前
SQL 窗口帧:ROWS vs RANGE 深度解析
数据库·sql·性能优化
+VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue鲜花商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
识君啊9 小时前
SpringBoot 事务管理解析 - @Transactional 的正确用法与常见坑
java·数据库·spring boot·后端
一个天蝎座 白勺 程序猿9 小时前
破译JSON密码:KingbaseES全场景JSON数据处理实战指南
数据库·sql·json·kingbasees·金仓数据库