Cluster结构图

                                      测试环境简介

Mysql cluster集群测试环境

4 data node,32G 8核cpu

4 sql node, 16G 8核cpu

1 manage node,16G 8核cpu

Cluster版本:

mysql-5.5.25ndb-7.2.7

单机innodb测试环境

32G内存 32核cpu  mysql版本 5.1.56

测试工具

1mysqlslap

2sysbench

备注1:mysqlslap测试图片中,纵坐标为耗时(s),横坐标为最大的客户端连接数。

备注2:sysbench测试图片中,纵坐标为执行操作数量,横坐标为最大的客户端连接数。


mysqlslap和sysbench的使用可以参考以下资料:

http://blog.csdn.net/mchdba/article/details/8960249

http://blog.csdn.net/mchdba/article/details/8951289

1.1 Mysqlslap50W并发写







1.2Mysqlslap100W并发写







1.3Mysqlslap200W并发写







1.4Mysqlslap400W并发写






2.2 sysbench500W读写






2.2 sysbench1000W读写






2.3sysbench1500W读写






3.1 sysbench500W






3.2 sysbench1000W






3.2 sysbench2000W






4.1单条复杂sql测试结果1

以上可以看出,工具压力测试之下,4个datanode下,mysqlcluster的读写性能都要高于innodb,但是一些复杂的sql,在节点数少的情况下,mysqlcluster的查询性能比innodb稍差,比如:

SELECTSQL_NO_CACHE l.brand_code,l.card_crc,l.card_ln,l.card_limit_money,l.card_no,

l.card_pwd,l.user_id,l.effect_date,l.expire_time,l.card_money,l.create_time,l.card_type,l.status,l.issue,l.isextension,l.active_time

FROM card_packagel  WHERE 1 ANDcard_type=20ANDis_reserve=0ORDER BYcard_lnDESC,card_noASC LIMIT 0,20;

4.2 单条复杂sql测试结果2

再看第二个复杂的sql,走全表扫描,检索的数据占据总量90%多(520W/550W)

SELECTSQL_NO_CACHE COUNT(card_no)FROMcard_couponl WHERE 1 ANDcard_type=30ANDis_reserve=0;从图中1节点2节点4节点的数据可以看出,比较复杂的sql或者检索数据比较多的sql,datanode越多,查询性能越高





5.1cluseterinnodb总结

从以上1.X、2.X、3.X以及4.X系列可以看出,4个datanode下,大量并发的情况下:

1,在写操作上ndbcluster是innodb的3到4倍

2,在读性能上,ndbcluster是innodb的2倍,压力越大并发量越大时,ndbcluster的查询性能越高

3,99.999%高可用,无延时

Cluster需要注意的地方:

1,如果没有异地灾备或者第二组cluster备的情况下,0.001%的几率下,所有的数据节点一起down机,重新启动整个cluster比较耗时,经过测试,10G的数据加载到内存中,大概需要25分钟。

2,需要很多数据节点,所以对机器的数量要求比较多。

3,并发量小,cluster相对于innodb没有很大的优势,基本持平;但是一些复杂的sql查询或者表扫描的情况下,数据节点少的时候,cluster的性能会与单机innodb持平

4,sql在group、order之前的数据集越少或越接近最终结果集 还是比较好的,反之结果多了网络开销和多次计算使得它的查询性能会与单机持平甚至略差。

5,一条sql允许write的总记录行数是与config.ini的参数相关联的。

MySQL Cluster初步测试结果汇总图示报告 --> 用mysqlslap与sysbench进行测试的更多相关文章

  1. [置顶] MySQL Cluster初步学习资料整理--安装部署新特性性能测试等

    1.1 mysql-cluster简介 简单的说,MySQLCluster实际上是在无共享存储设备的情况下实现的一种完全分布式数据库系统,其主要通过NDBCluster(简称NDB)存储引擎来实现. ...

  2. 第 16 章 MySQL Cluster

    前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和 Oracle Real Cl ...

  3. MySql(十六):MySql架构设计——MySQL Cluster

    前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和 Oracle Real Cl ...

  4. MySQL性能调优与架构设计——第 16 章 MySQL Cluster

    第 16 章 MySQL Cluster 前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等 ...

  5. sysbench压力测试工具简介和使用(一)

    sysbench压力测试工具安装和参数介绍 一.sysbench压力测试工具简介: sysbench是一个开源的.模块化的.跨平台的多线程性能测试工具,可以用来进行CPU.内存.磁盘I/O.线程.数据 ...

  6. MySQL Cluster搭建与测试

    MySQL Cluster是一个基于NDB Cluster存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和Oracle Real Cluster Ap ...

  7. MySQL Cluster测试过程中的错误汇总--ERROR 1296 (HY000)等等

    参考资料: http://dev.mysql.com/doc/refman/5.1/en/mysql-cluster-privilege-distribution.html http://www.cl ...

  8. MySQL Cluster 7.3.5 集群配置实例(入门篇)

    一.环境说明: CentOS6.3(32位) + MySQL Cluster 7.3.5,规划5台机器,资料如下: 节点分布情况: MGM:192.168.137. NDBD1:192.168.137 ...

  9. mysql集群 MySQL Cluster

    <?php /* 郑重说明2015年6月11日16:28:14,目前为止MySQL Cluster 社区版不支持INNODB,商业版支持,但是授权价格20W左右,so看此文档之前,考虑下钱 My ...

随机推荐

  1. 函数buf_LRU_free_from_common_LRU_list

    /******************************************************************//** Try to free a clean page fro ...

  2. jquery 图片放大

    上一篇是关于手风琴效果的,但是有时候我们需要放大的图片大小不规律,想要在屏幕中间显示大图. 图片放大可以做为单独的效果,也可以和其他的效果结合起来.比如Demo 里的Demo5.html是以图片无缝切 ...

  3. c# 产生随机字符串,包括大小写字母和数字

    #region MyRegion //產生密碼 protected static string GetPwd() { return CreateRandomNum123(2) + CreateRand ...

  4. 8.20 usaco

    summary:14 1.k短路 2.tarjan缩无向图点 3.复习了SA 4.差分约束 5.求第二短路 洛谷3824:dfs优化背包.开始的时候mle了,然后我就把a[i],w[i]去掉....就 ...

  5. Spring Data JPA初使用

    我们都知道Spring是一个非常优秀的JavaEE整合框架,它尽可能的减少我们开发的工作量和难度. 在持久层的业务逻辑方面,Spring开源组织又给我们带来了同样优秀的Spring Data JPA. ...

  6. mysql slave 错误解决

    执行CHANGE MASTER TO master_host............后报错 ERROR 1201 (HY000): Could not initialize master info s ...

  7. Java多线程同步——生产者消费者问题

    这是马士兵老师的Java视频教程里的一个生产者消费者问题的模型 public class ProduceConsumer{ public static void main(String[] args) ...

  8. android 实现模拟按键

    android 实现模拟按键方法一 通过Runtime实现,代码如下: try { String keyCommand = "input keyevent " + KeyEvent ...

  9. 清理vs工程文件(python2.7)

    本文记录了两种方法,用于对vs目录的清理工作,这两种方法都是用python2.7实现的,一个是基于文件的扩展名,一个是基于文件的大小: 基于文件大小的清理脚本: #-*- coding:utf-8 - ...

  10. Windows下ffmpeg的完美编译

    纠结了好几天,终于搞定了,小结一下. 1.下载ffmpeg源码,官网 2.编译环境Msys的安装配置,http://blog.csdn.net/jszj/article/details/4028716 ...