码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 超全整理,性能测试——数据库索引问题定位+分析(详细)


    目录:导读

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


    前言

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

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

    cd /etc/my.cnf
    
    vi my.cnf
    
    • 1
    • 2
    • 3

    添加如下配置:

    slow_query_log=1
    
    long_query_time=0.01
    
    • 1
    • 2
    • 3

    请添加图片描述

    2)重启数据库服务器

    systemctl restart mysqld
    
    • 1

    3)检查配置是否生效

    show variables like '%slow_query_log%';
    
    • 1

    在这里插入图片描述

    cd /var/lib/mysql
    
    • 1

    请添加图片描述

    2、慢查询日志分析

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

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

    请添加图片描述

    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 根据索引选择情况,估算查找数据所需读取的行数
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    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'
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在这里插入图片描述

    3)优化效果对比

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

    请添加图片描述

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

    请添加图片描述

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

    请添加图片描述

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

    一、Python编程入门到精通

    请添加图片描述

    二、接口自动化项目实战

    请添加图片描述

    三、Web自动化项目实战

    请添加图片描述

    四、App自动化项目实战

    请添加图片描述

    五、一线大厂简历

    请添加图片描述

    六、测试开发DevOps体系

    请添加图片描述

    七、常用自动化测试工具

    请添加图片描述

    八、JMeter性能测试

    请添加图片描述

    九、总结(尾部小惊喜)

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

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

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

  • 相关阅读:
    深入理解Java虚拟机(第3版)学习笔记——Java 内存模型与线程(超详细)
    2.12 PE结构:实现PE字节注入
    开源知识付费APP代码分析
    Linux 内核 6.5 发布,首次支持 Wi-Fi 7 和 USB4
    设置Mysql数据库开启远程连接
    tomcat web.xml文件中的session-config
    Java实现抽奖幸运儿
    YC-Framework版本更新:V1.0.9
    USB转IIC I2C SPI UART适配器模块可编程开发板应用工业数字接口转换
    【彩色图像处理GUI】各种颜色映射、重新调整大小和更改分辨率、伽玛校正,对比度,反转颜色(Matlab代码实现)
  • 原文地址:https://blog.csdn.net/shuang_waiwai/article/details/133882246
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号