JDBC连接openGauss6.0和PostgreSQL16.2性能对比

JDBC在Linux终端直接编译运行JAVA程序连接PG🆚OG数据库

看腻了就来听听视频演示吧:https://www.bilibili.com/video/BV1CH4y1N7xL/

前置准备

安装JDK:

详细安装步骤请问度娘,输入能正常返回即已安装

sql 复制代码
[root@db06 ~]# java -version
openjdk version "1.8.0_262"
OpenJDK Runtime Environment (build 1.8.0_262-b10)
OpenJDK 64-Bit Server VM (build 25.262-b10, mixed mode)
[root@db06 ~]# javac -version
javac 1.8.0_262

下载PostgreSQL驱动jar包:https://jdbc.postgresql.org/

下载openGuass驱动jar包:https://opengauss.org/zh/download/

Hello World

纯java代码,不涉及数据库层

编辑java文件代码,注意文件名需与类名同名

sql 复制代码
vi HelloWorld.java

public class HelloWorld{
    public static void main(String[] args){
        System.out.println("Hello World . . . ");
    }
}

编译运行:

sql 复制代码
javac HelloWorld.java
java HelloWorld

连接数据库(PostgreSQL)

需要用到驱动jar包,测试PG版本是16.2

创建Demo文件,文件名与类名同名

vi DBConnectDemo.java

sql 复制代码
import java.sql.*;

public class DBConnectDemo {

    public static void main(String[] args){
        // 相关ip,port,database,user,password需进行替换
        String url = "jdbc:postgresql://172.16.107.156:54321/testdb";
        String username = "muser";
        String password = "Test@123";
        try {
	        // 加载驱动
            Class.forName("org.postgresql.Driver");
            // 打印数据库版本
	        Connection conn = DriverManager.getConnection(url, username, password);
            Statement stmt = conn.createStatement();
            ResultSet result = stmt.executeQuery("select version();");
            while (result.next()){
                System.out.println("DB version : " + result.getString("version"));
            }
	        
            long avgtime = 0;
            int n = 10;		// 循环次数

	        // 循环打印连接建立时间
            for(int i=0;i<n;i++){
                long start = System.nanoTime();
                Connection connection = DriverManager.getConnection(url, username, password);
                long end = System.nanoTime() - start;
                System.out.println("connect success: " + end + " 纳秒");
                connection.close();
                avgtime += end;
            }
            System.out.println("avg time: " + avgtime/n + " 纳秒");
        }  catch (Exception e){
            e.printStackTrace();
        }
    }

}

编译运行:需要在路径前面加上 .: 来指定路径

javac编译时在同目录下可以不指定驱动jar包

java运行时则需要指定

sql 复制代码
javac -cp "/tmp/postgresql-42.5.2.jar" DBConnectDemo.java
java -cp "/tmp/postgresql-42.5.2.jar" DBConnectDemo (有问题)
java -cp ".:/tmp/postgresql-42.5.2.jar" DBConnectDemo
java -cp ".:./*" DBConnectDemo

连接数据库(openGauss)

openGauss出6.0了,下载个极简版来试试

opengauss连接需要调整驱动和数据库信息

sql 复制代码
String url = "jdbc:opengauss://172.16.107.156:15400/testdb";

            Class.forName("org.opengauss.Driver");

完整代码:

vi OGConnectDemo.java

sql 复制代码
import java.sql.*;

public class OGConnectDemo {

    public static void main(String[] args){
        // 相关ip,port,database,user,password需进行替换
        String url = "jdbc:opengauss://172.16.107.156:6543/testdb";
        String username = "muser";
        String password = "Test@1234";
        try {
                // 加载驱动
            Class.forName("org.opengauss.Driver");
            // 打印数据库版本
                Connection conn = DriverManager.getConnection(url, username, password);
            Statement stmt = conn.createStatement();
            ResultSet result = stmt.executeQuery("select version();");
            while (result.next()){
                System.out.println("DB version : " + result.getString("version"));
            }
                
            long avgtime = 0;
            int n = 10;		// 循环次数

                // 循环打印连接建立时间
            for(int i=0;i<n;i++){
                long start = System.nanoTime();
                Connection connection = DriverManager.getConnection(url, username, password);
                long end = System.nanoTime() - start;
                System.out.println("connect success: " + end + " 纳秒");
                connection.close();
                avgtime += end;
            }
            System.out.println("avg time: " + avgtime/n + " 纳秒");
        }  catch (Exception e){
            e.printStackTrace();
        }
    }

}

编译运行:OG会打印其他日志信息,这里我们把输出结果写到文件里

sql 复制代码
javac -cp ".:/tmp/opengauss-jdbc-6.0.0-RC1.jar" OGConnectDemo.java
java -cp .:/tmp/opengauss-jdbc-6.0.0-RC1.jar OGConnectDemo > OGConnectDemo.log
cat OGConnectDemo.log

PG 🆚 OG 总结

数据库 版本 连接调用次数 平均响应时间
PostgreSQL 16.2 100 25ms
openGauss 6.0 100 95ms
  • PostgreSQL 16.2 对比 openGauss 6.0 在连接创建上大概有3~4倍左右的性能优势,当然都是在毫秒级别
  • 针对高并发场景建议使用连接池来减少连接的频繁创建和关闭所带来的耗时
相关推荐
从零开始学习人工智能9 分钟前
Doris 数据库深度解析:架构、原理与实战应用
数据库·架构
LiRuiJie1 小时前
深入剖析MySQL锁机制,多事务并发场景锁竞争
数据库·mysql
2501_915374351 小时前
Faiss向量数据库全面解析:从原理到实战
数据库·faiss
睡觉待开机1 小时前
0. MySQL在Centos 7环境安装
数据库·mysql·centos
2501_915374351 小时前
Faiss vs Milvus 深度对比:向量数据库技术选型指南
数据库·milvus·faiss
傻啦嘿哟2 小时前
Python 数据分析与可视化实战:从数据清洗到图表呈现
大数据·数据库·人工智能
cookqq2 小时前
mongodb源码分析session异步接受asyncSourceMessage()客户端流变Message对象
数据库·sql·mongodb·nosql
呼拉拉呼拉2 小时前
Redis故障转移
数据库·redis·缓存·高可用架构
什么都想学的阿超2 小时前
【Redis系列 04】Redis高可用架构实战:主从复制与哨兵模式从零到生产
数据库·redis·架构
pp-周子晗(努力赶上课程进度版)3 小时前
【MySQL】视图、用户管理、MySQL使用C\C++连接
数据库·mysql