`
AreYouOK?
  • 浏览: 57300 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

JDBC数据库插入性能测试

阅读更多

版本

2008年8月21日,完成测试1的Oracle_Win、Mysql_Li、Mysql _Win、MSSQL部分。
2008年8月22日,完成测试2的Oracle_Win、Mysql_Li、Mysql _Win、MSSQL部分。

2008年8月23日,文档整理。

2008年8月25日,完成postgresql linux版本的测试1、测试2。
2008年8月27日,完成postgresql windows版本的测试1、测试2。



1.背景
这不是数据库性能的综合测试,这里只测试插入,并且是用JDBC插入。这是针对某种应用的某模块的简单模拟,不可能适用所有的情况。
假设系统的基本情况是,有后台线程要不停的读取数据,并写入流水表,写入以后就不会update。没有人使用系统的时候,就没有查询,偶尔才会有人来使用。查询的时候,因为数据量比较大,性能优化也是一个重要的问题,但不在本文讨论范围之内。

本文还没有完成,测试3还没有进行,并缺少Oracle Linux版本和PostgreSQL的数据。计划将来补上。

2.测试方法

测试1,简单表测试
建立3个一模一样的小表,只有3个数字类型的字段,一个主键,没有另外建索引。对不同的数据库执行以下测试:
A.用1个线程写一个表
B.用2个线程同时写2个不同的表
C.用2个线程写同一个表
D.用3个线程同时写3个不同的表
E.用3个线程写同一个表
每50条为一批进行批量操作,每5秒进行一次采样,稳定运行一段时间以后,取每秒插入的数据条数进行比较。用多个线程并发进行操作可以检查对双核CPU的利用效果。

测试2,普通表测试
与测试1相同,但是表不一样,建立3个一模一样的表。表包含10个各种字段,另外再单独建3个索引。

测试3,超大表测试(TODO)
与测试1相同,但是表不一样,建立3个一模一样的表。表包含100个以上的字段,10个索引。系统中有类似这样的流水表。

 

3.环境定义
3.1.硬件环境定义
笔记本
CPU Core Duo T2350(双核,1.86G)
硬盘120G
内存2G

Java程序和数据库跑在一个机器上测试确实不太好,不过只有这样的条件。另外,在小型客户那里的生产环境,有把数据库和Java应用服务器安装在一个机器的情况,因此这样也能说明一些问题。

3.2.操作系统定义
Windows平台:Windows XP Pro SP2,文件系统NTFS
Linux平台:Ubuntu 8.04,文件系统EXT3

Windows 平台上已经尽可能停用了无关的程序,比如杀毒软件等。
CPU在负载低的时候会自动降频到800M,在Windows下,使用软件RMClock将主频强制稳定在1.86G,避免CPU频率调整可能带来的性能波动。Linux下没有做这个处理(因为不知道用什么软件)。
为了偷懒是在Eclipse里面运行的,不过应该没有太多的影响。程序在循环中没有生成垃圾对象,不清楚数据库驱动程序会不会,但是应该不会频繁GC吧。

3.3.待测试数据库环境定义

 

数据库 OS 缩写 说明
Oracle 10g 10.2.01 Windows Oracle_win JDBC驱动程序用的安装Oracle后自带的。先整理磁盘碎片,然后建立新的表空间和用户,数据表空间5G,临时表空间200M,重做日志文件3×50M。
Oracle 10g 10.2.01 Linux Oracle_Li
MS SQL Server 2005 SP2 Windows MSSQL JDBC驱动程序为jtds1.2.2。磁盘碎片整理后建立数据库文件5G,日志文件100M。
MySQL 5.1.26 RC Linux Mysql_Li
存储引擎为InnoDB。JDBC驱动为mysql-connector-java-5.1.6-bin.jar
MySQL 5.1.26 RC Windows Mysql_Win 存储引擎为InnoDB。JDBC驱动为mysql-connector-java-5.1.6-bin.jar

Postgresql 8.3.3

Linux Pgsql_Li JDBC3 Postgresql Driver, Version 8.3-603。

Postgresql 8.3.3

Windows Pgsql_Win JDBC3 Postgresql Driver, Version 8.3-603。


数据库没有再做什么优化,简单的调整内存之类的参数,对测试结果基本没有影响。

4.测试结果

明细结果在附件(Eclipse工程)的result中。有的测试重复做过多次,基本上数据都是稳定的。
文件名命名规则是:数据库_s_线程数_表相同或不相同,s表示simple,n表示normal

输出每行表示一次采样,5秒1次,“本阶段平均”表示这5秒的平均速度,“共处理”是进程启动以后处理记录的总和,“平均”是根据启动后处理的记录总数和总时间计算出来的:

normal_evt 2170/s normal_evt 2050/s normal_evt 2170/s 本阶段平均6390/s 共处理3,1950条 平均6390/s


4.1.结果数据

测试1,简单表,3字段,1主键,无索引

条/秒 1线程1表 2线程2表 2线程1表 3线程3表 3线程1表
Oracle_Li





Oracle_Win 3,7205 5,6065 4,2437 5,0640 4,6861
Mysql_Li 1,0287 2,0449 1,2751 2,0397 1,4239
Mysql_Win 1020 1173 1167 1706 1671
MSSQL 2975 5584 5561 7705 7703
Pgsql_Li

1,3882

2,1870 2,2225 2,2402 2,4181
Pgsql_Win 1,0241 1,7287 1,7323 1,7153 1,8160



测试2,普通表,10字段,1主键,3索引

条/秒 1线程1表 2线程2表 2线程1表 3线程3表 3线程1表
Oracle_Li
Oracle_Win 1,9989 2,2001 1,8419 2,2442 1,8643
Mysql_Li 5857 1,0226 5890 1,0204 6180
Mysql_Win 973 1152 1142 1685 1595
MSSQL 2692 5155 5150 7173 6922
Pgsql_Li 8763 1,1492 1,2935 1,0141 1,2517
Pgsql_Win 7043 9997 9671 1,2274 1,2645



4.2.结果分析
不同的数据库在不同的方式下表现不一样,取最好的成绩,结果是Oracle_Win > Mysql_Li > MSSQL >> Mysql_Win。具体情况可以看上面的表。
除了Oracle以外,其他的数据库插入的性能都很稳定。
CPU占用率通常在20%~60%之间,随着线程数的增加略有提高。

下面对单个数据库做分析:
4.2.1.Mysql_Li

mysql的特点是,当使用2个线程插入2个不同的表时,性能立刻提高了整整一倍,使用3个线程插入3个表的时候却,相比2线程2表没有提高。看起来,要用至少两个线程才能充分利用双核的两个CPU(其实是4个线程,2个java线程,2个数据库线程,但是java线程资源占用率较小,主要瓶颈还是在数据库)。
当使用多个线程同时入1个表时,性能只是稍微有点提高。

4.2.2.Mysql_Win
都说Mysql Windows版本性能不行,没想到差那么多。但是有两个很有意思的特点(MS SQL差不多也有这样的特点):第一是测试2的数据比测试1几乎没有下降,而测试2的表要复杂的多,看来mysql有个瓶颈在我们不知道的地方,使得面对一个很简单的表,速度也上不去;第二是不断增加线程,性能始终能够提高,后来我又做了4线程和5线程的测试,仍然如此,不过提高的幅度越来越小。

4.2.3.Oracle_Win
插入性能很不稳定。如果把采样时间缩短为1秒,会发现大部分时间性能是基本稳定的,但每隔一小段时间,会基本失去响应(插入速度能降低到200以下),估计是重做日志的切换引起的,Oracle重做日志是3×50M。
随着数据量的增加,性能稍有下降,因此每次测试先都先truncate表,测试1的5次运行每次都在单表数据量达到1000w时结束测试,测试2在500w时结束测试。尚未测试在极大的数据量情况下会怎么样,但oracle在这种情况下的表现应该是久经考验的,估计可能到了一定的程度会稳定吧。

oracle的数据相当的好,并且其他数据库往往需要增加线程来获得更好的成绩,而oracle在1个线程的情况下能得到相对最好的成绩,增加线程以后提高不多。
当使用2个线程入2个表时,测试1提高50%,测试2略微提高。3个线程入3表则没有提高。
多个线程入同一个表的时候,测试1性能只有一些提高,而测试2竟出现了下降,但这种情况也不是不可思议的,测试2有10个字段,包括主键有4个索引,多个线程可能在争夺资源中出现了锁定。

cpu占有率波动很大,通常在10%~70%左右以大约20秒的周期剧烈波动,随着线程数的增加,占有率稍有上升。cpu占有率低时,写入速度也急剧下降,应该是切换重做日志引起。

最初做Oracle这个测试的时候,是把表建在一个已经有很多数据的表空间里面。后来,做碎片整理,然后新建表空间和用户,再测试,性能提高了30%。

4.2.4.MSSQL
MSSQL的特点和Windows下的Mysql差不多,测试1和测试2数据相当,似乎有别的瓶颈。刚开始的时候,数据真是非常可怜(与它假象的对手oracle相比),不过在增加线程后出现了可观的提高,不然就要沦落为和Mysql_win一个量级了。

 4.2.5.Pgsql_Li
Postgresql的数据比mysql略高。

 4.2.6.Pgsql_Win
postgresql在windows下性能只出现了少量下降。有一个特点是在3个线程的时候CPU占用率接近到100%。

 

 

  • dbtest.zip (328.8 KB)
  • 描述: 代码工程和本文的pdf版本文档,更新于2008-08-29
  • 下载次数: 170
分享到:
评论

相关推荐

    Mybatis与JDBC批量插入MySQL数据库性能测试

    通过这样的性能测试,我们可以了解到在特定场景下,Mybatis和JDBC哪个更适合批量插入操作。通常,Mybatis由于其封装和优化,可能会在易用性和性能之间取得更好的平衡。但具体选择应根据项目需求和实际环境进行权衡。...

    使用JDBC插入大量数据的性能测试

    使用jdbc向数据库插入100000条记录,分别使用statement,PreparedStatement,及PreparedStatement+批处理3种方式进行测试:1、使用statement插入100000条记录  使用jdbc向数据库插入100000条记录,分别使用...

    软件测试中使用JDBC插入大量数据的性能测试

    jdbc数据软件测试中使用JDBC插入大量数据的性能测试使用jdbc向数据库插入100000条记录,分别使用statement,PreparedStatement,及PreparedStatement+批处理3种方式进行测试:1、使用statement插入100000条记录...

    Oracle数据库性能测试软件swingbench

    Swingbench作为Oracle公司推出的性能测试工具,为数据库管理员和开发者提供了强大的测试能力。这款由Java语言编写的软件旨在模拟真实的用户负载,对数据库进行压力测试,以评估其在高并发情况下的性能表现。 ...

    jdbc 连接数据库测试项目

    **JDBC连接数据库测试项目详解** Java Database Connectivity (JDBC) 是Java编程语言中用于与关系型数据库交互的一组标准API。它允许开发者执行SQL语句、管理事务、处理结果集以及进行各种数据库操作。本项目是针对...

    Java使用JDBC向MySQL数据库批次插入10W条数据(测试效率)

    在Java开发中,当需要向MySQL数据库大量插入数据时,使用JDBC的批量处理功能可以显著提高效率。本文将详细讲解如何使用JDBC批量插入10万条数据,并探讨其背后的原理和优化策略。 批量处理在JDBC中主要通过Statement...

    使用jmeter测试数据库

    JMeter 是一款功能强大且流行的性能测试工具,广泛应用于测试 Web 应用程序、数据库等系统的性能。下面,我们将通过一个简单的例子,演示如何使用 JMeter 测试数据库的性能。 JMeter 简介 JMeter 是 Apache 软件...

    数据库原理实验六 ODBC和JDBC数据库编程.doc

    【数据库原理实验六:ODBC和JDBC数据库编程】 ODBC(Open Database Connectivity)和JDBC(Java Database Connectivity)是两种广泛使用的数据库访问接口,它们为应用程序提供了与数据库交互的标准方式。本实验主要...

    经过详细设计和分析实现web开发基于jdbc数据库jsp开发

    10. **部署与测试**:完成开发后,应用需要在Web服务器上部署,如Tomcat,并进行功能测试和性能测试,确保系统稳定可靠。 以上就是基于JDBC数据库的JSP开发在实现酒店管理系统中的关键知识点,这些技术和概念构成了...

    浪潮数据库压力测试.pdf

    在进行浪潮数据库压力测试时,使用了jmeter工具,这是因为jmeter是一个开源的性能测试工具,它可以用于测试静态和动态资源,比如静态文件、JavaScrip、图片、数据库、FTP服务器等等。jmeter对于数据库的测试可以模拟...

    PI 实时数据库 JDBC 说明文档

    虽然PI数据库不是传统的关系型数据库,但它支持一部分SQL标准,包括选择(SELECT)、插入(INSERT)、更新(UPDATE)和删除(DELETE)操作。"PI-JDBC-2017-R2-Administrator-Guide.pdf"很可能详述了如何在PI环境中...

    JDBC驱动和测试代码

    总的来说,理解和掌握JDBC驱动及其测试对于任何Java开发人员来说都是至关重要的,因为数据库操作是许多应用程序的核心部分。通过这个项目,你可以深入学习如何高效、安全地与数据库进行交互,并确保代码的质量和稳定...

    jdbc连接数据库的方式2

    三、以下列出了在使用JDBC来连接Oracle数据库时可以使用的一些技巧,这些技巧能够使我们更好地发挥系统的性能和实现更多的功能(系转载)。  1、在客户端软件开发中使用Thin驱动程序  在开发Java软件方面,Oracle...

    数据库操作的单元测试

    2. **植入测试数据**:根据测试案例的需求,向数据库中插入预定义的数据。 3. **执行测试**:运行实际的测试代码。 4. **清理数据库状态**:测试完成后,恢复数据库至最初的备份状态。 **1.1.2 DBunit的三大核心...

    Jmeter需要的JDBC测试jar包

    它能够模拟多个并发用户执行各种操作,如HTTP请求、FTP传输、SMTP协议、JDBC数据库连接等,从而评估系统在高负载下的性能表现。JMeter的强大之处在于其灵活性和可扩展性,用户可以自定义测试计划,实现复杂的测试...

    通过JDBC连接oracle数据库的十大技巧

    ### 通过JDBC连接Oracle数据库的十大技巧 #### 1. 使用Thin驱动程序 在Java客户端软件开发过程中,Oracle提供了多种驱动程序供...通过运用上述技巧,可以显著提升通过JDBC连接Oracle数据库的应用程序的性能和稳定性。

    timesten系列八:性能对比测试

    #### 性能测试背景 为了评估Timesten在实际应用中的性能优势,本文采用了一种较为简单的测试方法来模拟真实的业务场景。通过编写Java程序并执行批量数据插入操作,记录并分析了不同的连接配置下Timesten的响应时间和...

    三种JDBC批量插入编程方法的比较

    在`JDBCBatchInsertTest.java`中,你可能会看到对这些批量插入方法的性能测试,通过计时和比较来确定哪种方法更适合特定的场景。 总结来说,选择JDBC批量插入方法应基于数据插入的特性和需求。PreparedStatement...

    jmeter的JDBC测试

    本篇文章将深入探讨如何利用JMeter进行JDBC(Java Database Connectivity)测试,即与数据库交互的性能测试。 首先,我们需要了解JDBC测试的基础概念。JDBC是Java平台中的一个标准接口,它允许Java程序连接到各种...

Global site tag (gtag.js) - Google Analytics