Mysqlslap性能测试MySQL三种存储引擎

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
简介: Mysqlslap性能测试MySQL三种存储引擎

测试环境:

操作系统:CentOS6.5_x64

Mysql版本:5.1.71

mysqlslap是设计来模拟多个客户端负载MySQL服务器,并报告每个阶段的时间诊断程序。

mysqlslap运行在三个阶段

1.创建模式,表,以及可选的存储程序或数据,用于测试。这个阶段使用单一客户端连接。

2.运行负载测试。这个阶段可以使用很多客户端连接。

3.清理(断开连接,如果指定删除表)。这个阶段使用单一客户端连接。

Mysql数据库默认最大连接数是100,一般生产环境是不够的,在my.cnf [mysqld]下添加  max_connections=1024 增加到1024,重启Mysql。

Mysql默认使用是MyISAM存储引擎,如下查看:

222129818.png

[root@localhost ~]# mysqlslap --concurrency=100,200 --iterations=1 --auto-generate-sql --auto-generate-sql-load-type=mixed --number-int-cols=20 --number-char-cols=30 --engine=innodb --create-schema=test --number-of-queries=1024 --host=localhost --user=root --password=123.com --debug-info

参数说明:

--concurrency=          #并发连接数量(可逗号隔开),例如:concurrency=100,200

--engines=              #要测试的存储引擎,逗号隔开;

--iterations=           #运行多少次后,得到结果;

--auto-generate-sql     #自动生成SQL脚本来测试;

--auto-generate-sql-load-type= #测试类型是read还是write,还是mixed(混合);

--number-of-queries=    #执行查询的次数;

--number-int-cols=      #测试表int字段类型的数量;

--number-char-cols=     #测试表的char类型字段的数量;

--create-schema =test   #创建测试的数据库;

--debug-info            #输出CPU、内存等系统相关信息;

测试说明:模拟测试两次读写并发,第一次100,第二次200,自动生成SQL脚本,测试表包含20个init字段,30个char字段,每次执行1024查询请求。测试引擎分别是myisam,innodb,memory。

MyISAM测试

222145449.png

InnoDB测试

222153758.png

Memory测试

222203829.png 测试结果说明:

Myisam第一次100客户端同时发起增查用1.913/s,第二次200客户端同时发起增查用1.49/s

Innodb第一次100客户端同时发起增查用2.94/s,第二次200客户端同时发起增查用3.683/s

Memory第一次100客户端同时发起增查用1.963/s,第二次200客户端同时发起增查用1.599/s

由此可见MyISAM存储引擎处理性能是最好的,也是最常用的,但不支持事务。

InonDB存储引擎提供了事务型数据引(ACID),在事务型引擎里使用最多的。具有事务回滚,系统修复等特点。

Memory存储引擎数据都在内存中进行操作的,默认使用HASH索引,具有很高的插入、查询处理效率,因为数据存在内存中,当Mysql重启或关闭机器这些数据都会消失。 在本次测试中未能体现其优势。不支持事务。

上述数据仅供参考,根据本身业务需求选择合适存储引擎,需要注意的是服务器的性能不同直接影响到测试的结果,应多次测试,求平均值。


相关实践学习
自建数据库迁移到云数据库
本场景将引导您将网站的自建数据库平滑迁移至云数据库RDS。通过使用RDS,您可以获得稳定、可靠和安全的企业级数据库服务,可以更加专注于发展核心业务,无需过多担心数据库的管理和维护。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
11月前
|
存储 SQL 关系型数据库
MySQL存储引擎简介
在选择相应的存储引擎时,需要充分考虑实际业务场景、性能需求和数据一致性要求,从而为数据管理提供最佳支持。
493 17
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
2232 57
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
12月前
|
SQL 缓存 关系型数据库
使用温InnoDB缓冲池启动MySQL测试
使用温InnoDB缓冲池启动MySQL测试
224 0
|
Oracle 关系型数据库 MySQL
使用崖山YMP 迁移 Oracle/MySQL 至YashanDB 23.2 验证测试
这篇文章是作者尚雷关于使用崖山YMP迁移Oracle/MySQL至YashanDB 23.2的验证测试分享。介绍了YMP的产品信息,包括架构、版本支持等,还详细阐述了外置库部署、YMP部署、访问YMP、数据源管理、任务管理(创建任务、迁移配置、离线迁移、校验初始化、一致性校验)及MySQL迁移的全过程。
|
12月前
|
SQL 缓存 关系型数据库
MySQL8.4 Enterprise安装Firewall及测试
MySQL8.4 Enterprise安装Firewall及测试
386 0
|
12月前
|
安全 关系型数据库 MySQL
MySQL8使用物理文件恢复MyISAM表测试
MySQL8使用物理文件恢复MyISAM表测试
247 0
|
存储 关系型数据库 MySQL
MYSQL支持的存储引擎有哪些, 有什么区别
MYSQL存储引擎有很多, 常用的就二种 : MyISAM和InnerDB , 者两种存储引擎的区别 ; ● MyISAM支持256TB的数据存储 , InnerDB只支持64TB的数据存储 ● MyISAM 不支持事务 , InnerDB支持事务 ● MyISAM 不支持外键 , InnerDB支持外键
|
存储 关系型数据库 MySQL
MySQL存储引擎详述:InnoDB为何胜出?
MySQL 是最流行的开源关系型数据库之一,其存储引擎设计是其高效灵活的关键。InnoDB 作为默认存储引擎,支持事务、行级锁和外键约束,适用于高并发读写和数据完整性要求高的场景;而 MyISAM 不支持事务,适合读密集且对事务要求不高的应用。根据不同需求选择合适的存储引擎至关重要,官方推荐大多数场景使用 InnoDB。
712 7
|
7月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
484 158
|
7月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。

推荐镜像

更多