网站首页 > 开源技术 正文
1. 压测环境
为了尽可能的客观公正,本次选择同一物理机上的两台虚拟机,一台用作数据库服务器,一台用作运行压测工具mysqlslap,操作系统均为Ubuntu Server 22.04LTS。
数据库服务器的虚拟机配置:2核4G(配置虽低,但是用作横向对比不影响结果),安装完系统做好基本配置后即创建快照便于快速恢复,这样MySQL和MariaDB都运行在同一台虚拟机当中,排除环境因素导致的性能影响。压测数据也采用导出和导入的方式,确保数据完全一致。
MySQL和MariaDB版本分别为8.0.32和10.11.2,均为当前最新稳定版。压测工具mysqlslap。
压测的大致过程:
1、 安装数据库,分别生成30万,200万和500万几种压测数据,分别用mysqldump导出数据备份。
2、 重新恢复到虚拟机快照,全新安装MariaDB,导入备份数据进行压测,记录压测结果。
3、 重新复到虚拟机快照,安装MySQL,导入备份数据进行压测,记录压测结果。
4、 每次压测前先执行2次压测,不记录结果,作为数据库的热身。从第3次开始记录,连续测试5次,取平均值。
2. 压测过程
2.1. 生成压测数据
主要就是创建表和模拟数据,实际使用数据库大部分时候会用到两表关联查询,且通常是查询索引字段,但通常不是主键,所以创建两张表user和userlog,通过字段uname(varchar,有索引)进行关联查询。
其中user表固定1万条数据,userlog表分别模拟30万,200万和500万条数据几种情况压测。
为节约篇幅,建表语句略。
- 数据模拟
mysqlslap --create-schema=test --no-drop -c 100 -i 100 -h 10.0.2.12 -u user -p'user123!' --query="insert ignore into \`user\`(uname, age) values(SUBSTR(TO_BASE64(CONCAT(10000000000+rand()*1000000000,rand()*1000000000)),4,16), 10+rand()*70)";
mysqlslap --create-schema=test --no-drop -c 1 -i 30 -h 10.0.2.12 -u user -p'user123!' --query="insert ignore into userlog (rid, uname, val) select uuid(), uname, rand()*5000000 from \`user\`"
- 备份数据
sudo mysqldump --databases test -u root>test_30w.sql
2.2.安装数据库和恢复数据
略
2.3. 压测
# 并发100/300连接,每个连接只查询1次;循环10次
mysqlslap --create-schema=test --no-drop -c 100 -i 10 -h 10.0.2.12 -u user -p'user123!' --query=" set @val=round(rand()*10000);select u.uname,u.age,l.rid,l.val from user u join userlog l on u.uname=l.uname where u.rid=@val limit 20;"
# 并发100/300连接,每个连接查询10次,不循环。
mysqlslap --create-schema=test --no-drop -c 100 --number-of-queries 1000 -h 10.0.2.12 -u user -p'user123!' --query=" set @val=round(rand()*10000);select u.uname,u.age,l.rid,l.val from user u join userlog l on u.uname=l.uname where u.rid=@val limit 20;"
3. 压测结果
压测结果数据如下:
可以看出,不同数据量和不同压力下,MariaDB的性能要比MySQL高40%到50%。所以,怎么选不言自明。
猜你喜欢
- 2024-12-05 重磅!10年数据库专家为MySQL填充亿级数据,要不要观摩一下?
- 2024-12-05 MySQL 8.0 在线修改redo log 容量
- 2024-12-05 这个不可思议的死锁你会解吗?
- 2024-08-01 微盟数据库的涅槃之旅(微盟管理平台)
- 2024-08-01 运维工程师的进阶之道(运维工程师的进阶之道有哪些)
- 2024-08-01 IT系统性能测试方案设计(性能测试体系)
- 2024-08-01 mysql information_schema元数据和索引介绍
- 2024-08-01 第08问:我有表,你有数据么?(我有手表你有吗)
- 2024-08-01 Xtrabackup备份Xtrabackup_binlog_info文件记录GTID信息是否准确
- 2024-08-01 MySQL的文件系统(Linux环境)(mysql 的文件在哪里)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- jdk (81)
- putty (66)
- rufus (78)
- 内网穿透 (89)
- okhttp (70)
- powertoys (74)
- windowsterminal (81)
- netcat (65)
- ghostscript (65)
- veracrypt (65)
- asp.netcore (70)
- wrk (67)
- aspose.words (80)
- itk (80)
- ajaxfileupload.js (66)
- sqlhelper (67)
- express.js (67)
- phpmailer (67)
- xjar (70)
- redisclient (78)
- wakeonlan (66)
- tinygo (85)
- startbbs (72)
- webftp (82)
- vsvim (79)
本文暂时没有评论,来添加一个吧(●'◡'●)