jmeter性能优化之mysql监控sql慢查询语句分析

接上次博客:基础配置

多用户登录并退出jmx文件:百度网盘

提取码:0000

一、练习jmeter脚本检测mysql慢查询
  1. 随意找一个脚本(多用户登录并退出),并发数设置300、500后分别查看mysql监控平台

  2. 启动后查看,主要查看mysql连接情况

    下图查看:Max Used Connections最大176,

    分析查看:设置的最大连接数为512,实际最大只能连接176,其他的在等待连接或者在排队

  3. 查看Mysql Slow Queries慢查询,最大慢查询在7.28s,平均是0.38s

  4. 主机基础监控CPU、内存都在90%以上,可以先处理CPU,内存问题

  5. 观察聚合报告,压测300,500都没有异常率

  6. 通过表查看慢查询数据,只筛选2024-06-09 18:31:00之后的数据按降序排列

bash 复制代码
select * from mysql.slow_log where start_time>'2024-06-09 18:31:00' order by start_time desc;

查询出有这么多条慢查询sql

start_time :开始时间

user_host:监控主机IP

query_time:花费的查询时长(按照设置的,超过1s的都会被筛选出来)

  1. 随意选择一个语句,选择后面的(BLOB 3.32)点击上面的文本(或备注),会在表格下面出现慢查询的sql语句

  2. 复制该语句,进行执行后可能会为空(不关注这里),注意要对应数据

  3. 点击上面的解释,显示如下

    type=ALL:代表全表搜索,没有带任何索引

    rows=906014:从90W条数据中查询,依次类推,把慢查询的语句给研发查看进行优化

    type类型有哪些,和执行速度:CONST>EQ_REF>REF>RANEG>INDEX>ALL

    ALL全表搜索:数据库查询里最慢的一种

开发优化后再次压测,如果再出现慢查询再次优化,直到满足需求为止!

相关推荐
小兜全糖(xdqt)24 分钟前
mysql数据同步到sql server
mysql·adb
Karoku06627 分钟前
【企业级分布式系统】Zabbix监控系统与部署安装
运维·服务器·数据库·redis·mysql·zabbix
周全全1 小时前
MySQL报错解决:The user specified as a definer (‘root‘@‘%‘) does not exist
android·数据库·mysql
白云如幻1 小时前
MySQL的分组函数
数据库·mysql
小码哥说测试1 小时前
接口测试用例设计的关键步骤与技巧解析!
自动化测试·测试工具·jmeter·职场和发展·测试用例·接口测试·postman
人工智能培训咨询叶梓3 小时前
探索开放资源上指令微调语言模型的现状
人工智能·语言模型·自然语言处理·性能优化·调优·大模型微调·指令微调
秋意钟3 小时前
MySQL日期类型选择建议
数据库·mysql
ac-er88884 小时前
MySQL如何实现PHP输入安全
mysql·安全·php
小钱c75 小时前
Mac下安装Apache JMeter并启动
jmeter·macos·apache
桀桀桀桀桀桀5 小时前
数据库中的用户管理和权限管理
数据库·mysql