1.安装性能监控工具

1.1 nmon

安装nmon

de  >#下载地址
http://nmon.sourceforge.net/pmwiki.php?n=Site.Download
nmon16g_x86.tar.gz 9MB #解压缩
mkdir nmon;
tar xvf nmon16g_x86.tar.gzde>

执行监控命令

de  >./nmon16g_x86_rhel72 -f -t -s 5 -c 360

-f:按标准格式输出文件:_YYYYMMDD_HHMM.nmon;
-t:输出中包括占用率较高的进程
-s 5:每 5 秒进行一次数据采集-c CLEAR -c 360 :一共采集 360 次,即总共采集半小时数据 #回车后,将自动在当前目录生成一个 hostname_timeSeries.nmon 的文件:
例如:mysqltest_171113_230.nmon #采集结束之后,通过 sort 命令可以将 nmon 结果文件转换为 csv 文件:
sort MysqlTest_171113_2307.nmon >MysqlTest_171113_2307.csv
执行完 sort 命令后即可在当前目录生产 mysqldb_170704_0045.csv 文件de>
1.2 excel 分析器
de  >#下载地址:
https://www.ibm.com/developerworks/community/wikis/home?lang=en#!/wiki/Power+Systems/page/nmon_analyser
nmon_analyser_v51_2.zip #解压
解压后两个文件,一个Word,一个Excel,Word是说明文档,Excel就是我们需要的工具了。
双击打开这个Excel文件,点击“Analyze nmon data”,然后选择我们刚才生成的nmon文件,
大概十几秒左右(数据量不同,生成的时间也不一样)就会生成我们需要的报表了。
此时我们就可以更加直观的观看CPU,内存等数据了。de>
1.3 基准测试工具TestTools
de  >#下载地址
https://github.com/MyCATApache/Mycat-download/blob/master/1.5-RELEASE/
Mycat-server-1.5.1-RELEASE-20161130213509-testtool.tar.gz #解压
tar xvf Mycat-server-1.5.1-RELEASE-20161130213509-testtool.tar.gzde>

2开始基准测试

2.1 准备性能测试脚本
de  >[root@MysqlTest bin]# cd /tool/testtool/mycat/bin
[root@MysqlTest bin]# ls -lrt
total 44
-rwxr-xr-x 1 root root 603 Dec 13 2015 test_stand_update_perf.sh
-rwxr-xr-x 1 root root 612 Dec 13 2015 test_stand_update_perf.bat
-rwxr-xr-x 1 root root 603 Dec 13 2015 test_stand_select_perf.sh
-rwxr-xr-x 1 root root 613 Dec 13 2015 test_stand_select_perf.bat
-rwxr-xr-x 1 root root 602 Dec 13 2015 test_stand_merge_sel_perf.sh
-rwxr-xr-x 1 root root 611 Dec 13 2015 test_stand_merge_sel_perf.bat
-rwxr-xr-x 1 root root 591 Dec 13 2015 test_stand_insert_perf.sh
-rwxr-xr-x 1 root root 600 Dec 13 2015 test_stand_insert_perf.bat
-rwxr-xr-x 1 root root 602 Dec 13 2015 test_globaltable_insert_perf.sh
-rwxr-xr-x 1 root root 611 Dec 13 2015 test_globaltable_insert_perf.bat
-rwxr-xr-x 1 root root 602 Dec 13 2015 test_globalseq_insert_perf.bat #准备脚本:
使用testtool 需要先建立仿真测试文件,person-insert.sql 文件内容如下:de>

注意 sql=后面的语句一定要在一行中 不能换行,不然执行时会报错

de  >vi person-insert.sql

total=100000
sql=insert into person(id,name, school, age, addr, zcode, birth, score)
values(NEXT VALUE FOR MYCATSEQ_PERSON,'${char([a-f,0-9]8:10)}', ${int(1-1000)}, ${int(18-60)},
'chengdu-${enum(jinniu,qingyang,jinjiang)}', ${int(610000-610200)},
'${date(yyyyMMdd-[1980-1990]y)}', ${int(60-100)}) #Int:数字,${int(..)} 可以是,${int(10-999)}或者,${int(10,999)}
前者表示从10到999的值;后者表示 10 或者 999
#Date:日期,如${date(yyyyMMddHHmmssSSS-[2014-2015]y)}
表示从2014到2015年的时间,前面是输出格式,符合 Java 标准
#Char:字符串,${char([0-9]2:2)}表示从0到9的字符,长度为2位
(2:2,}${char([a-f,0-9]8:8)}表示从a到 f以及0到9的字符串随机组成,定常为8位。
#Enmu:枚举,表示从指定范围内获取一个值, ${enum(0000,0001,0002)},
里面可以是任意字符串或数字等内容。de>
2.2 开始性能测试,针对不同step开始测试:10,100,10000 三个类型.

每次切换步长,最好初始化下

de  >#初始化序列号 初始化表
mysql> truncate table PERSON;
Query OK, 0 rows affected (0.75 sec) #use db1
mysql> truncate table MYCAT_SEQUENCE;
Query OK, 0 rows affected (0.20 sec)de>

#设置步长为 10
mysql> INSERT INTO MYCAT_SEQUENCE(name,current_value,increment) VALUES (‘PERSON’,100000, 10);

执行测试脚本

de  >[root@MysqlTest bin]# ./test_stand_insert_perf.sh jdbc:mysql://192.168.2.136:8066/TESTDB
test test 10 file=person-insert.sqlde>

执行结果

de  >#步长 10
finishend:100000 failed:0
used time total:1236seconds
tps:80.89960359194241 #步长100
finishend:100000 failed:0
used time total:234seconds
tps:427.16787697565144 #步长10000
15 02:23:29 finished records :98900 failed:0 speed:836.6608012994044
15 02:23:30 finished records :99400 failed:0 speed:833.8086769788276
finishend:100000 failed:0
used time total:120seconds
tps:832.6394671107411de>

总结:

de  >随着step增大,tps显著增长,总的执行时间也在下降明显;
但是在step增大到一定范围的时候,tps 不再有显著增长,相应执行时间也下降趋于平稳。
原因是:
由于自增的 sequence 是在表中存放的,每次插入数据的时候,取序号都受到这张表
的访问速度限制。所以,在 step 比较小的时候,访问表的次数较多,因此 tps 比较
低,执行效率低下;在 step 比较大的时候,访问表的次数较少,因此 tps 比较高;
而且插入采用的批处理,步长越长,一次插入的条数就越多,所以时间也就越短。de>
2.3 三台机器性能分析

数据库机器的cpu io 性能图

mycat机器的cpu io 性能图

testtool机器的cpu io 性能图

总结:

de  > 1.mysql数据库cpu和io变化比较明显,但是 io的占用率相对大很多。步长达到一定程度后,趋势平稳!
2.mycat服务器cpu变化明显,io基本没什么负载。步长达到一定程度后,cpu趋势平稳!
3.testtool机器 cpu变化明显,io无负载。 cpu占用也小!de>

mycat实战之性能测试的更多相关文章

  1. mycat读写分离性能测试

    1.    MySQL主从配置 我们的方案设计基于Mysql的主从数据复制功能,以下是基于mysql5.5以上版本最新的主从配置. 开启mysql主从数据复制,主要在mysql的my.ini文件中设置 ...

  2. Mycat实战之数据迁移(oracle -- mysql)

    1.案例场景: Mycat 后面接一个 Oracle 实例与一个 MySQL 实例,假设用户表,订单表,转账记录表, Oracle 字符集为 GBK 的,MySQL 字符集则要求 UTF8的 完成用户 ...

  3. MYCAT实战之分片迁移

    实践扩容 1.要求: travelrecord 表定义为10个分片,尝试将10个分片中的 2 个分片转移到第二台MySQL上, 并完成记录要求,最快的数据迁移做法,中断业务时间最短 2.针对分片以及迁 ...

  4. Mycat实战之主键数据库自增方式

    创建一个 person表,主键为Id,hash方式分片,主键自增(采用数据库方式) #person表结构如下 Id,主键,Mycat自增主键 name,字符串,16字节最长 school,毕业学校,数 ...

  5. Mycat实战之离散分片

    1 枚举分片(customer表) #### 1.1 修改配置信息加载配置文件 datanode hash-int vi partition-hash-int.txt db1=0 db2=1 [roo ...

  6. Mycat实战之连续分片

    1 按照日期(天)分片: 从开始日期算起,按照天数来分片 例如,从2017-11-01,每10天一个分片且可以指定结束日期 注意事项:需要提前将分片规划好,建好,否则有可能日期超出实际配置分片数 1. ...

  7. Mycat实战之配置EP分片

    ER分片介绍 以mycat逻辑库里面自带的例子,例如客户(CUSTOMER)跟订单(orders)以及订单条目(orders_item),订单条目依 赖订单表,订单表依赖客户,这样客户与订单以及订单条 ...

  8. Mycat实战之日志分析

    环境搭建参见之前发的一篇:http://www.cnblogs.com/chinesern/p/7667106.html 1修改log4j.xml 配置增加其他级别调试以及验证是否自动加载 cat / ...

  9. Mycat实战之新增基于hash分片的表

    1. 修改rule.xml hash分片规则 主要改两个地方: vi rule.xml 分片数量,这里改为3 对应 三个库 hash规则 默认是id列 这里为 PROVINCE 2. reload 加 ...

随机推荐

  1. Laravel5.1 文件管理

    Laravel提供了一套很好用的文件系统 方便于管理文件夹和文件,支持Amazon S3和Rackspace云存储等驱动. 1 配置 文件系统的配置文件在 config/filesyetems.php ...

  2. malloc free, new delete 的异同点

    相同点: 都可以动态的申请并释放内存 不同点: 1. 用法不同 <1> malloc 函数为 void* malloc(size_t size), 用于申请一块长度为 size 字节的内存 ...

  3. ios开发之 -- 单例类

    单例模式是一种软件设计模式,再它的核心结构中指包含一个被称为单例类的特殊类. 通过单例模式可以保证系统中一个类只有一个势力而且该势力易于外界访问,从而方便对势力个数的控制并节约系统资源.如果希望在系统 ...

  4. The type org.springframework.dao.DataAccessException cannot be resolved. It is indirectly referenced from required .class files

    使用spring框架提供的JDBC模板操作数据库时,提示错误 解决方案:导入事务管理jar包spring-tx-4.2.4.RELEASE.jar

  5. 深度解析Objective-C笔试题

    2011-08-11 17:39 佚名 互联网 字号:T | T 本文介绍的是Objective-C笔试题,先来问一个,为什么很多内置类如UITableViewController的delegate属 ...

  6. Maven的安装配置及初次创建项目与java单元测试工具JUnit

    Maven  安装     1.把maven安装包解压到某个位置     2.配置M2_HOME环境变量指向这个位置 3.在path环境变量中添加;%M2_HOME%\bin 配置镜像 国内的阿里云镜 ...

  7. Python全栈day21-22-23(模块)

    一,python的模块 Python 模块(Module),是一个 Python 文件,以 .py 结尾,包含了 Python 对象定义和Python语句. 模块让你能够有逻辑地组织你的 Python ...

  8. 3、二、c# 面向对像编程。类,结构、C# 数据类型(引用类型、值 类型、指针类型)、ref参数与out参数、方法的重载、静态类型与静态成员、继承与多态、委托与事件

    一.类 定义类使用class关键字. <access specifier> class class_name { // member variables 成员变量 <access s ...

  9. 阿里云OSS分片上传DEMO

    分片传输规则 1.不能超过10000片,2.每片必须大于100KB using System; using System.Collections.Generic; using System.Compo ...

  10. Android中的 style 和 theme

    通过设置 view 控件的属性,达到设置android UI的目的,如果某些 属性值复用率很高,可以考虑将属性单独声明在 style中,这样就可以达到复用的效果. 一.style Style 概念:A ...