当前位置: 首页 > news >正文

超全整理,性能测试——数据库索引问题定位+分析(详细)

目录:导读

    • 前言
    • 一、Python编程入门到精通
    • 二、接口自动化项目实战
    • 三、Web自动化项目实战
    • 四、App自动化项目实战
    • 五、一线大厂简历
    • 六、测试开发DevOps体系
    • 七、常用自动化测试工具
    • 八、JMeter性能测试
    • 九、总结(尾部小惊喜)


前言

1、数据库服务器添加慢查询配置

1)my.cnf文件添加监控慢查询配置

cd /etc/my.cnfvi my.cnf

添加如下配置:

slow_query_log=1long_query_time=0.01

请添加图片描述

2)重启数据库服务器

systemctl restart mysqld

3)检查配置是否生效

show variables like '%slow_query_log%';

在这里插入图片描述

cd /var/lib/mysql

请添加图片描述

2、慢查询日志分析

1)打印查询次数前20的sql语句

mysqldumpslow -s at -t 20 huangshao-slow.log

请添加图片描述

2)对慢查询sql语句进行执行计划分析

在navicat里面拷贝慢查询语句,执行前加explain表示分析sql

在这里插入图片描述

Const:表中只有一个匹配行,用到primary key或unique key
Eq_ref:唯一性索引扫描,key的所有部分被连接联接查询使用,且key是unique或primary key
ref:非唯一性索引扫描,或只使用了联合索引的最左前缀Range:索引范围扫描,在索引列上进行给定范围内的检索,如between,in(1,100) Index:遍历索引...All:全表扫描
Prossible key:使用哪个索引能找到行
Keys:sql语句使用的索引
rows:mysql 根据索引选择情况,估算查找数据所需读取的行数

3、优化方案

1)添加索引

选择sql语句中where字句中的字段添加索引,并保存索引

在这里插入图片描述

索引类型:

Normal:普通索引,允许重复数据
Unique:非普通索引,不允许重复数据
Fulltext:全文索引,适用于大字段

在这里插入图片描述

2)sql执行计划分析

explain
select
id, user_name, password, age, gender, phone_num, email, address, create_time, update_time
from user
where user_name = 'user_100'

在这里插入图片描述

3)优化效果对比

Tps提升10倍,响应时间减少90%

请添加图片描述

应用服务器cpu使用率提升65%

请添加图片描述

数据库服务器cpu使用率提升80%

请添加图片描述

下面是我整理的2023年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

在人生的舞台上,不必逞强,但一定要坚持。没有捷径可循,只有脚踏实地的奋斗才是通往成功的道路。勇敢追逐梦想,用汗水浇灌,终将绽放辉煌。

每一次尝试都是一种勇气,每一次放弃都是一种懦弱。不要畏惧挑战,谦逊学习,坚持奋斗,未来属于你的光芒将会越发灿烂。相信自己,勇往直前!

生命的壮丽之处,在于每一次奋斗的坚持与努力。不要畏惧失败,抓住机会,迎接挑战。用心燃烧梦想,拼搏奋斗,只有这样,你才能超越自我,创造属于自己的辉煌人生。

http://www.lryc.cn/news/197613.html

相关文章:

  • 44springboot摄影跟拍预定管理系统
  • Flink之窗口触发机制及自定义Trigger的使用
  • 蓝牙资讯|2024年智能家居新趋势,蓝牙助力智能家居发展
  • 机器学习 | Python实现GA-XGBoost遗传算法优化极限梯度提升树特征分类模型调参
  • 手部关键点检测3:Pytorch实现手部关键点检测(手部姿势估计)含训练代码和数据集
  • 服务日志性能调优,由log引出的巨坑
  • 【VR】【Unity】如何调整Quest2的隐藏系统时间日期
  • C++之设计模式
  • Django ORM查询
  • 如何在CentOS 7中卸载Python 2.7,并安装3.X
  • 10.17七段数码管单个多个(部分)
  • linux静态库与动态库
  • LeetCode 面试题 10.03. 搜索旋转数组
  • SpringCloudSleuth异步线程支持和传递
  • 如何使用 Disco 将黑白照片彩色化
  • ChatGPT AIGC 制作大屏可视化分析案例
  • 2023年9款好用的在线流程图软件推荐!
  • 剑指Offer || 044.在每个树行中找最大值
  • ESP32网络开发实例-UDP数据发送与接收
  • 液压自动化成套设备比例阀放大器
  • 专业144,总分440+,上岸西北工业大学827西工大信号与系统考研经验分享
  • JQuery - template.js 完美解决动态展示轮播图,轮播图不显示问题
  • CC2540和CC2541的区别简单解析
  • Java8 新特性之Stream(八)-- Stream的collect()与Collectors的联合运用
  • SpringBoot基础详解
  • 学会Docker之---应用场景和基本操作
  • C++_linux下_非阻塞键盘控制_程序暂停和继续
  • SQL AND, OR and NOT(与,或不是运算符)
  • Python网络编程之Socket(套接字)
  • 金山终端安全系统V9.0 SQL注入漏洞复现