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

相关推荐
LSL666_13 分钟前
MybatisPlus条件构造器(上)
java·数据库·mysql·mybatisplus
U-52184F6928 分钟前
深入理解“隐式共享”与“写时复制”:从性能魔法到内存深坑
java·数据库·算法
程序猿ZhangSir1 小时前
详解了解 Redis IO多路复用底层原理,Select,poll,epoll三者的区别?
数据库·redis·缓存
U-52184F691 小时前
深度解析:从 Qt 的 Q_D 宏说起,C++ 工业级 SDK 是如何保证 ABI 稳定性的
数据库·c++·qt
Gauss松鼠会1 小时前
【GaussDB】LLVM技术在GaussDB等数据库中的应用
大数据·数据库·架构·数据库开发·gaussdb·llvm
IMPYLH1 小时前
Linux 的 dir 命令
linux·运维·服务器·数据库
wfsm1 小时前
mysql事务
数据库·mysql
SadSunset2 小时前
第一章:Redis 入门介绍
数据库·redis·缓存
weixin_464307632 小时前
QT智能指针
java·数据库·qt
王仲肖2 小时前
PostgreSQL VACUUM 与 AUTOVACUUM 深度解析
数据库·postgresql