mysql 并发测试
针对上一节做一些针对公司业务的测试。
我们来做一些压力测试。
服务器配置:
操作系统: 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 并发测试的更多相关文章
- MySQL 并发测试中,线程数和数据库连接池的实验
我一直以来,对性能测试中,连接池的大小要如何配置,不是太清楚: 就我所知道的,就DB自带对连接数的限制,在sqlserver中用select @@connection 可以查到, 在代码中,可以配置D ...
- paip.提升性能---mysql 性能 测试以及 参数调整.txt
paip.提升性能---mysql 性能 测试以及 参数调整.txt 作者Attilax 艾龙, EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://b ...
- spring boot2.0.4集成druid,用jmeter并发测试工具调用接口,druid查看监控的结果
一.项目介绍(本项目用的编程语言是jdk8,项目源码:https://github.com/zhzhair/spring-boot-druid.git) 1.引入pom依赖: <dependen ...
- 使用mysqlslap进行MySQL压力测试
使用mysqlslap进行MySQL压力测试发表于236 天前 ? MySQL ? 暂无评论 MySQL从5.1.4版开始带有一个压力测试工具mysqlslap,通过模拟多个并发客户端访问mysql来 ...
- mysql 通过测试'for update',深入了解行锁、表锁、索引
mysql 通过测试'for update',深入了解行锁.表锁.索引 条件 FOR UPDATE 仅适用于InnoDB存储引擎,且必须在事务区块(BEGIN/COMMIT)中才能生效. mysql默 ...
- mysql基础测试
mysql基础测试 测试原因 为什么需要做性能测试 模拟比当前系统更高的负载,找出性能瓶颈 重现线上异常 测试不同硬件软件配置 规划未来的业务增长 测试分类 性能测试的分类 设备层的测试 ...
- Atitit.并发测试解决方案(2) -----获取随机数据库记录 随机抽取数据 随机排序 原理and实现
Atitit.并发测试解决方案(2) -----获取随机数据库记录 随机抽取数据 随机排序 1. 应用场景 1 2. 随机抽取数据原理 1 3. 常用的实现方法:::数据库随机函数 1 4. Mssq ...
- MySQL Router 测试使用 转
MySQL Router 测试使用 . 特性 MySQL Router 并没有包括一些特别新的特性, 总体上看中规中矩, 不过 first-available 和插件两个特性挺有意思, 后续会进行讲解 ...
- appium 并发测试
Android并发测试 Appium提供了在一台设备上启动多个Android会话的方案,而这个方案需要你输入不同的指令来启动多个Appium服务来实现. 启动多个Android会话的重要指令包括: - ...
随机推荐
- html+css基础 - 个人备忘录
//======================html部分===================// 表现内容<meta http-equiv="Content-Type" ...
- XML 反序列化成对象,绑定到CheckBoxList控件
1.前台 <div class="control-group"> <label class="control-label"> 导航名称: ...
- 【Linux】- CentOS 7 安装.NET Core 2.1
添加dotnet产品Feed 在安装.NET Core之前,您需要注册Microsoft产品Feed. 这只需要做一次. 首先,注册Microsoft签名密钥,然后添加Microsoft产品Feed. ...
- 【Linux】- ps -ef |grep 命令
ps:将某个进程显示出来 grep:查找 |:管道命令 表示ps命令与grep同时执行 PS是LINUX下最常用的也是非常强大的进程查看命令 grep命令是查找,是一种强大的文本搜索工具,它能使用正则 ...
- 面试中常用排序算法的python实现和性能分析
这篇是关于排序的,把常见的排序算法和面试中经常提到的一些问题整理了一下.这里面大概有3个需要提到的问题: 虽然专业是数学,但是自己还是比较讨厌繁琐的公式,所以基本上文章所有的逻辑,我都尽可能的用大白话 ...
- MVC绕过登陆界面验证时HttpContext.Current.User.Identity.Name取值为空问题解决方法
Global.asax界面添加如下方法: void FormsAuthentication_Authenticate(object sender, FormsAuthenticationEventAr ...
- WPF一个对象显示多个属性
一个对象显示多个属性使用模板的方法: 如图: <dataTemplate x:key="MyDataTemplate">
- Select-poll-epoll-简介
1. Python的select()方法直接调用操作系统的IO接口,它监控sockets,open files, and pipes(所有带fileno()方法的文件句柄)何时变成readable 和 ...
- 虚拟机如何进入BIOS
- HDU.1233 还是畅通工程(Prim)
HDU.1233 还是畅通工程(Prim) 题意分析 首先给出n,代表村庄的个数 然后出n*(n-1)/2个信息,每个信息包括村庄的起点,终点,距离, 要求求出最小生成树的权值之和. 注意村庄的编号从 ...