当前位置:首页 > AI技术 > 正文内容

mysql性能基准测试工具推荐 使用sysbench进行压力测试实战案例|Duuu笔记

admin2周前 (03-31)AI技术23

sysbench 是 MySQL 压测的事实工业标准,因其 Lua 脚本灵活性、指标可对标 SLO 且被主流云厂商广泛采用;必须源码编译以适配 MySQL 8.0+ 认证机制;prepare 卡住多因权限、网络或 max_allowed_packet 不足;不同 Lua 脚本事务结构差异大,直接影响瓶颈定位;需按目标调参,否则测不到真实瓶颈。

sysbench 是当前 MySQL 压测最稳、最可控的选择

不是“之一”,而是事实上的工业级标准:它被 Percona、阿里云 PolarDB、腾讯云 TDSQL 等大量生产环境用于上线前容量评估和故障复现。相比 tpcc-

mysql

或 mysqlslap,

sysbench

的 Lua 脚本机制让它能灵活模拟真实业务读写比例、事务结构和热点分布,且结果指标(TPS/QPS/95% latency)可直接对标 SLO。

安装必须走源码编译,尤其在新版 MySQL 8.0+ 或自建集群场景

包管理器装的

sysbench

(如

yum install sysbench

)往往链接旧版 MySQL client lib,连接 MySQL 8.0+ 时容易报

Authentication plugin 'caching_sha2_password' cannot be loaded

或直接段错误。源码编译能精准控制依赖版本。

先装对的开发库:

sudo apt install libmysqlclient-dev libssl-dev

(Ubuntu/Debian)或

sudo yum install mysql-devel openssl-devel

(CentOS/RHEL)

务必指定 MySQL 路径(尤其当 MySQL 是 tar.gz 自定义部署):

./configure --with-mysql-includes=/usr/local/mysql/include --with-mysql-libs=/usr/local/mysql/lib

编译后验证驱动是否生效:

sysbench --help | grep mysql

应显示

mysql

在 supported drivers 列表中

prepare 阶段卡住或报错,大概率是权限或网络配置问题

sysbench ... prepare

不只是建表,还会执行大量 INSERT,失败时错误信息常被掩盖。常见现象是命令无响应、日志里只有

FATAL: failed to execute MySQL query

,但没具体 SQL。

Action Figure AI

借助Action Figure AI的先进技术,瞬间将照片转化为定制动作人偶。

下载

确认账号有

CREATE

INSERT

SELECT

INDEX

权限,且 host 匹配(别用

'user'@'%'

却连本地

127.0.0.1

检查 MySQL 的

max_allowed_packet

是否太小(默认 4MB),

sysbench

插入百万行时易触发

Packets larger than max_allowed_packet are not allowed

若用 ProxySQL 或中间件,确认其未拦截

PREPARE

EXECUTE

语句(某些版本会静默拒绝)

oltp_read_write.lua 和 oltp_point_select.lua 的行为差异远不止“读写比”

很多人以为换脚本只是改读写比例,实际它们的事务结构、索引使用方式、锁竞争强度完全不同——这直接影响你看到的瓶颈是 CPU、IO 还是锁等待。

oltp_read_write.lua

默认每事务含 10 条 SQL(包括 UPDATE、DELETE、INSERT),主键更新+二级索引维护压力大,容易暴露

innodb_buffer_pool_size

不足或

innodb_log_file_size

过小

oltp_point_select.lua

只做主键等值查询,几乎不写盘,压的是 Buffer Pool 命中率和 CPU 解析能力;若这里 latency 突增,优先查

innodb_buffer_pool_reads

是否飙升

别直接跑默认参数!比如

--tables=10 --table-size=1000000

生成 10GB 数据,但你的 buffer pool 才 2GB —— 结果全是物理读,测的不是 MySQL,是磁盘

真正难的不是跑起来,而是让

sysbench

测出你关心的那个瓶颈。比如想看高并发下死锁频率,就得关掉自动重试(加

--reconnect=off

),再盯着

SHOW ENGINE INNODB STATUS

里的 LATEST DETECTED DEADLOCK;想验证连接池效果,就得把

--threads

从 16 拉到 256,同时观察 MySQL 的

Threads_connected

Aborted_connects

。这些细节不调,数据再好看也没参考价值。

相关文章

推荐10个AI人工智能技术网站

除了研究和开发人工智能技术,OpenAI还积极参与人工智能伦理和安全的研究和探讨。 认为,人工智能技术的发展必须遵循伦理和法律的规范,以确保人工智能的应用不会对人类带来负面影响。...

一文讲清神经网络、BP神经网络、深度学习的关系

人工神经网络中的顶级代表。往往说《神经网络》就是指《BP神经网络》。 大家研究着各种神经网络,研究得不亦乐乎, 来了两个家伙Romelhart 和Mcclelland,...

前端开发高级应用:MuleRun如何连接Slack通知 MuleRun消息推送集成配置步骤实战案例|Duuu笔记

若MuleRun无法向Slack推送通知,需依次配置Incoming Webhook或Bot Token、在MuleRun中设置对应通知目标参数,并通过最小化任务测试验证;常见失败原因包括凭据错误、权...

深入理解优化:如何利用 Gemini 3.1 的阶梯计费策略?企业级大规模调用实务完全指南|Duuu笔记

需深入理解Gemini 3.1阶梯计费与调用联动关系,通过识别阶梯区间、请求级Token预估截断、多模型路由调度、响应缓存去重、项目拆分配额绑定五种路径优化成本。 ☞☞☞AI 智能聊天, 问答助手,...

前端开发实战详解:骡子快跑怎么注册账号 骡子快跑账号注册流程最佳实践|Duuu笔记

骡子快跑注册仅需1分钟,但激活码需从Discord指定频道获取,输错3次将锁账户24小时;积分与注册邮箱强绑定且不可更换;部分地区即使注册成功也无法运行Agent。 ☞☞☞AI 智能聊天, 问答助手...

AI实战详解:Perplexity 怎么做市场调研 Perplexity 市场分析实操教程【商业】最佳实践|Duuu笔记

掌握Perplexity AI市场调研需五步:一、结构化提问嵌入地域/时间/主体/指标四要素;二、限定PDF等原始信源提升可信度;三、分步提问生成制表符分隔文本以自动导入Excel;四、启用Pro S...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。