针对上一节做一些针对公司业务的测试。

我们来做一些压力测试。

服务器配置:

操作系统: centos 5.6-64

CPU: 8核

内存: 8G

硬盘:sas

文件系统:linux

MySQL:5.6.

网卡: 100M

网络环境: 良好

数据库表:

c_account_customer,这里用来根据id查询、更新某些字段

CREATE TABLE `c_account_customer` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '表主键',
`customer_id` int(10) unsigned NOT NULL COMMENT '客户号',
`item_id` int(10) unsigned NOT NULL COMMENT '科目号',
`ref_id` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '业务识别号',
`debit_balance` decimal(14,2) DEFAULT NULL COMMENT '借方余额',
`credit_balance` decimal(14,2) DEFAULT NULL COMMENT '贷方余额',
`last_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '最后更新时间',
PRIMARY KEY (`id`),
UNIQUE KEY `customer_id` (`customer_id`,`item_id`,`ref_id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

c_entry_company用来插入借、贷科目信息

CREATE TABLE `c_entry_company` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '表主键',
`entity_id` int(10) unsigned NOT NULL COMMENT '机构号',
`item_id` int(10) unsigned NOT NULL COMMENT '科目号',
`ref_id` int(11) NOT NULL DEFAULT '0' COMMENT '业务识别号',
`direction` tinyint(3) unsigned NOT NULL COMMENT '记账方向',
`amount` decimal(10,0) NOT NULL COMMENT '记账金额',
`operation` int(11) DEFAULT NULL COMMENT '操作类型号',
`operation_id` int(11) DEFAULT NULL COMMENT '操作流水号',
`note` varchar(200) DEFAULT NULL COMMENT '业务备注',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '数据创建时间',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

testvalue表,用来记录事务中查询到的字段值,进行结果分析:

CREATE TABLE `testvalue` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`val` decimal(14,2) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

针对上述三个数据表的事务操作:

CREATE DEFINER=`root`@`localhost` PROCEDURE `Test`(out debitb decimal(14,2))
BEGIN

START TRANSACTION ;

select @db:=debit_balance from c_account_customer where id=1 for update;
set debitb=@db;
insert into abacus.testvalue (val) values (@db);
insert into abacus.c_entry_customer (customer_id,item_id,ref_id,direction,amount,operation,operation_id,note) values (1,1,1,1,1,1,1,1);
insert into abacus.c_entry_customer (customer_id,item_id,ref_id,direction,amount,operation,operation_id,note) values (1,2,1,1,1,1,1,1);
update abacus.c_account_customer set debit_balance=@db+1 where id=1;
commit;

END

C#测试代码

public static void TestComplicating()
{
Console.WriteLine("开始:"+DateTime.Now);
bool b = true;
int num = 0;
DateTime start = DateTime.Now;
while (b)
{
num++;
Complicating();

if (DateTime.Now.AddMinutes(-30)>start)
{
b = false;
}
}
Console.WriteLine("结束:" + DateTime.Now+";循环次数:"+num);
}

public static void Complicating()
{
for (int i = 0; i < 10; i++)
{
Thread thread = new Thread(new ParameterizedThreadStart(Execution));
thread.Start(i);

}
}

public static void Execution(object i)
{
MySqlParameter debitb = new MySqlParameter("?debitb", MySqlDbType.Decimal);
debitb.Direction = ParameterDirection.Output;

IDataParameter[] parameters = new IDataParameter[] {
debitb
};
mysqlhelper.RunProcedure("Test", parameters, "test");

//Task.Factory.StartNew(() =>Logs.jobStatus.Info("更新前值:"+debitb.Value+";当前线程id:" + Thread.CurrentThread.ManagedThreadId + ";循环:" + (int)i));

}

第一组测试结果

Mysql 服务器最大连接数: 1024

.net 客户端连接池最大连接数:500

不模拟耗时操作

测试前先插入一条数据:insert into abacus.c_account_customer (customer_id,item_id,ref_id,debit_balance,credit_balance)values(1,1,1,10000,10000);

第1次: 100个并发 ,完成耗时3秒,无数据丢失,无数据错误。
第2次: 500个并发 ,完成耗时10秒,无数据丢失,无数据错误。
第3次: 5个并发,while循环中持续1分钟,完成耗时1分钟,事务次数171540,无数据丢失,无数据错误。
第4次: 10并发,while循环中持续10分钟,完成耗时10分钟,事务1885640次数 ,无丢数据( c_entry_company中3771280条数据),无数据错误(debit_balance=1895640.00 =1885640+10000)。
第5次: 10并发,while循环中持续30分钟,完成耗时30分钟,循环次数(694861),事务6948610次数 ,无丢数据( c_entry_company中13897220条数据),无数据错误(debit_balance=6958610.00 =6948610+10000)。

图例:

上图中 ,

图1,2 为第4次测试时mysql服务器截图。

图3为第4次测试时mysql服务器每秒执行事务次数。

图4为第5次测试时mysql服务器每分钟执行事务次数。

注:欢迎提出更优、合理的方案。

mysql 并发测试的更多相关文章

  1. MySQL 并发测试中,线程数和数据库连接池的实验

    我一直以来,对性能测试中,连接池的大小要如何配置,不是太清楚: 就我所知道的,就DB自带对连接数的限制,在sqlserver中用select @@connection 可以查到, 在代码中,可以配置D ...

  2. paip.提升性能---mysql 性能 测试以及 参数调整.txt

    paip.提升性能---mysql 性能 测试以及 参数调整.txt 作者Attilax  艾龙,  EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://b ...

  3. spring boot2.0.4集成druid,用jmeter并发测试工具调用接口,druid查看监控的结果

    一.项目介绍(本项目用的编程语言是jdk8,项目源码:https://github.com/zhzhair/spring-boot-druid.git) 1.引入pom依赖: <dependen ...

  4. 使用mysqlslap进行MySQL压力测试

    使用mysqlslap进行MySQL压力测试发表于236 天前 ? MySQL ? 暂无评论 MySQL从5.1.4版开始带有一个压力测试工具mysqlslap,通过模拟多个并发客户端访问mysql来 ...

  5. mysql 通过测试'for update',深入了解行锁、表锁、索引

    mysql 通过测试'for update',深入了解行锁.表锁.索引 条件 FOR UPDATE 仅适用于InnoDB存储引擎,且必须在事务区块(BEGIN/COMMIT)中才能生效. mysql默 ...

  6. mysql基础测试

    mysql基础测试 测试原因   为什么需要做性能测试 模拟比当前系统更高的负载,找出性能瓶颈 重现线上异常 测试不同硬件软件配置 规划未来的业务增长   测试分类   性能测试的分类 设备层的测试 ...

  7. Atitit.并发测试解决方案(2) -----获取随机数据库记录 随机抽取数据 随机排序 原理and实现

    Atitit.并发测试解决方案(2) -----获取随机数据库记录 随机抽取数据 随机排序 1. 应用场景 1 2. 随机抽取数据原理 1 3. 常用的实现方法:::数据库随机函数 1 4. Mssq ...

  8. MySQL Router 测试使用 转

    MySQL Router 测试使用 . 特性 MySQL Router 并没有包括一些特别新的特性, 总体上看中规中矩, 不过 first-available 和插件两个特性挺有意思, 后续会进行讲解 ...

  9. appium 并发测试

    Android并发测试 Appium提供了在一台设备上启动多个Android会话的方案,而这个方案需要你输入不同的指令来启动多个Appium服务来实现. 启动多个Android会话的重要指令包括: - ...

随机推荐

  1. SFTP服务器之创建普通用户

    这篇博客主要写以下几点: 1.介绍SFTP服务器 2.用SFTP服务器的root用户a创建普通用户 3.修改普通用户名称以及默认登入时的目录名称 4.创建普通用户踩过的坑以及收获 一.介绍SFTP服务 ...

  2. DAY6敏捷冲刺

    站立式会议 工作安排 (1)服务器配置 服务器端项目结构调整 (2)数据库配置 单词学习记录+用户信息 (3)客户端 客户端项目结构调整,代码功能分离 燃尽图 燃尽图有误,已重新修改,先贴卡片的界面, ...

  3. 201621044079 韩烨 week11-作业11-多线程

    作业11-多线程 参考资料 多线程参考文件 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 2. 书面作业 本次PTA作业题集多线程 1. 源代码阅读:多线程程序 ...

  4. Mysql8 忘记Root密码(转)

    第一步:修改配置文件免密码登录mysql vim /etc/my.cnf 1.2 在 [mysqld]最后加上如下语句 并保持退出文件: skip-grant-tables 1.3 重启mysql服务 ...

  5. 安装django 提示ImportError: No module named setuptools

    安装django前要先安装setuptools 先安装一些必要的包,否则会报错:Python build finished, but the necessary bits to build these ...

  6. java 基础 --多态--009

    1, 多态:同一个对象(事物),在不同时刻体现出来的不同状态 2, 多态的前提: A: 要有继承关系 B: 要有方法的重写 C: 要有父类引用指向子类对象 父 f = new 子(); 3, 多态访问 ...

  7. Maven 3-Maven依赖版本冲突的分析及解决小结 (阿里,美团,京东面试)

    举例A依赖于B及C,而B又依赖于X.Y,而C依赖于X.M,则A除引B及C的依赖包下,还会引入X,Y,M的依赖包(一般情况下了,Maven可通过<scope>等若干种方式控制传递依赖).这里 ...

  8. matlab 中try/catch语句

    try的作用是让Matlab尝试执行一些语句,执行过程中如果出错,则执行catch部分的语句,其语法: try (command1)组命令1总被执行,错误时跳出此结构 catch (command2) ...

  9. springboot2.0 如何异步操作,@Async失效,无法进入异步

    springboot异步操作可以使用@EnableAsync和@Async两个注解,本质就是多线程和动态代理. 一.配置一个线程池 @Configuration @EnableAsync//开启异步 ...

  10. 【转】C# typeof()实例详解

    转自:http://www.cnblogs.com/lm3515/archive/2010/09/02/1815725.html typeof(C# 参考) 用于获取类型的 System.Type 对 ...