【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高可用性实验脚本~

相关推荐
Elastic 中国社区官方博客7 小时前
从平均值到任意百分位数:Elasticsearch 在 ES|QL 中原生支持指数直方图
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索·prometheus
今儿敲了吗7 小时前
数据库(四)——关系数据库SQL语言
数据库·笔记·sql
麦聪聊数据7 小时前
SQL与数据库开发(二):用 CTE 重构嵌套查询与处理树形结构
sql·数据库开发
brevity_souls7 小时前
SQL server格式化日期
运维·服务器·数据库
虹科网络安全7 小时前
艾体宝干货|Active-Active/Active-Passive 数据库架构解析:高可用设计中的权衡与选型
数据库·数据库架构
麦聪聊数据7 小时前
SQL与数据库开发(一):用窗口函数替代应用层的嵌套循环
数据库·sql·数据库开发
努力进修7 小时前
连接条件下推原理与实战:解决子查询、CTE大数据量性能问题
数据库·oracle
小贺儿开发7 小时前
Unity3D 年会抽奖工具(附体验链接)
数据库·unity·excel·人机交互·工具·抽奖·互动
imuliuliang7 小时前
Laravel8.x核心特性全解析
数据库
战南诚7 小时前
mysql的坑 - count计数
数据库·mysql