百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

性能压测数据告诉你MySQL和MariaDB该怎么选

cac55 2024-10-17 08:00 70 浏览 0 评论

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%。所以,怎么选不言自明。

相关推荐

这些端口关闭后,系统会更安全!系统高危端口及其关闭方法?

在这高速发展的网络信息时代,信息安全显得非常重要,病毒、木马、非法侵入等安全事件经常发生。在我们使用电脑过程中,为了确保系统安全,以下高危端口必须关闭,防患于未然。一.Windows系统的445端口...

什么是安全组_什么是安全组件

安全组是一种虚拟防火墙,具备状态检测和数据包过滤功能,用于在云计算环境中设置网络访问控制,保护云服务器(ECS实例)、负载均衡、云数据库等资源。核心特性:虚拟防火墙:安全组控制云资源的出入站流量,决定...

针对单个网站的渗透思路(精)_网站渗透步骤

欢迎搜索公众号:白帽子左一每天分享更多黑客技能,工具及体系化视频教程(免费领首先,当我们拿到一个网站的域名或者IP的时候。最先要做的是信息收集。下面着重介绍一下信息收集模块一、信息收集——端口扫描与分...

风险突出的高危端口汇总 一网打尽 !

高危端口一直是攻击者关注的焦点,了解这些端口的风险、攻击方式及防护策略至关重要。一、文件传输类端口1.TCP20/21:FTP服务端口FTP(文件传输协议)用于文件的上传和下载。其明文传输特性使得...

指定IP地址进行远程访问服务器设置方法(windows系统)

我们有很多服务器经常受到外界网络的干扰,入侵者们通过扫描3389端口爆破密码非法进入我们的服务器,这时,我们可以配置服务器IP安全策略来限制一些IP访问,大大提高了服务器的安全。实验环境:服务端:...

服务器被黑,如何查找入侵、攻击痕迹呢?

本文出自头条号老王谈运维,转载请说明出处。引言:随着网络的越来越普及,使用的越来越频繁,木马病毒也随之侵入进来并且肆无忌惮。如何将病毒拒之门外,已成为我们普通大众必须具备的一项技能。这样,你才能使木马...

win10 telnet命令怎么查看端口是否打开

可能大家也会遇到这个问题,win10telnet命令查看端口是否打开的步骤是什么?具体方法如下:1、键盘输入快捷键WIN+R,打开运行窗口。2、输入cmd,点击确定按钮。3、弹出cmd命令行窗...

Crysis勒索病毒针对政企服务器攻击升级 腾讯安全展开全面防御

近日,腾讯安全御见威胁情报中心监测发现,Crysis勒索病毒在国内传播升级,感染数量呈上升趋势,该病毒主要通过RDP弱口令爆破传播入侵政企机构,加密重要数据,由于该病毒的加密破坏暂无法解密,被攻击后将...

Windows端口详解,这几个端口不能开!

一、血泪警告这7个端口开着电脑秒变公共厕所445端口:勒索病毒专用通道永恒之蓝病毒最爱突破口,文件共享功能成致命漏洞。企业内网还敢用用,个人电脑开着就是作死135-139端口:网络邻居成内鬼,Wind...

网络通讯笔记_网络通讯笔记怎么写

网络通讯一、NIC(网卡)二、CMD命令提示符三、服务、协议与端口常见的计算机服务常见的计算机端口与协议四、DOS命令1、基本DOS命令五、地址一、NIC(网卡)网络接口控制器又叫网络适配器也就是...

服务器远程端口是什么意思?什么是服务器远程端口?

什么是服务器远程端口?如图:IP冒号后面的数字这就是服务器的一个远程端口服务器远程端口是什么意思?服务器远程端口是服务器通信服务中的一个服务端窗口号码,取值范围是1-65535.一个服务器里面包含服务...

服务器节点到底是啥?看完这篇全明白,旧电脑也能派上大用场

不少朋友看了我用旧电脑改服务器节点的文章,后台都在问:“服务器节点到底能干啥?”其实这东西没那么神秘,今天用大白话讲讲,看完你就知道家里的旧设备藏着多大潜力。服务器节点:网络世界的“小工位”简单说...

广东通管局预警:勒索病毒威胁“关键信息基础设施”,应高度警惕

来源:澎湃新闻据广东省通信管理局网站消息,广东省通信管理局5月12日发布了《关于勒索病毒对关键信息基础设施威胁的预警通报》。通报称,5月7日,美国最大燃油运输管道商“科洛尼尔”(ColonialP...

80端口和443端口是什么?服务器端口干什么用的?

80和443端口是最常见的2个端口,都是提供网络WEB浏览服务所需要的端口,一台服务器通过不同的端口,提供不同的服务。80端口服务:HTTP(HyperTextTransportProtocol)...

从单日网络安全风险看当前网络安全状况

一、核心结论(从单日数据看全局风险)通过对2025年8月18日这一天的非法访问数据深度分析,可以清晰看到:网络环境中的安全威胁呈现高频次、多目标、全球化三大特征。单日4557次非法访问尝试,覆盖22、...

取消回复欢迎 发表评论: