MYSQL进阶-查询优化- 实战 STATUS

回城传送–》《100天精通MYSQL从入门到就业》

文末有送书活动,可以参加!

文章目录

  • 一、练习题目
  • 二、SQL思路
    • SQL进阶-查询优化- SHOW STATUS
      • 初始化数据
      • 解法
        • SHOW STATUS是什么
        • 实战经验:常用的mysql状态查询
          • 1、QPS(每秒处理的请求数量)
            • 计算思路:
            • Questions和 Queries的区别
          • 2、TPS(每秒处理的事务数量)
            • 计算思路:
          • 3、key Buffer 命中率
          • 4、InnoDB Buffer命中率
          • 5、query cache命中率
          • 6 、table_cache(table_open_cache) 命中率
          • 6、thread cache命中率
            • 优化
          • 7、tmp table相关状况分析
          • 8、binlog cache
          • 9、innodb_log_waits
          • 10、锁状态
  • 三、总结
  • 四、参考
  • 五、粉丝福利
    • 福利0
    • 福利1
    • 福利2

一、练习题目

题目链接难度
SQL进阶-查询优化- SHOW STATUS★★★☆☆

二、SQL思路

SQL进阶-查询优化- SHOW STATUS

在这里插入图片描述

初始化数据

这里写入初始化表结构,初始化数据的sql

解法

SHOW STATUS是什么

SHOW STATUS 能获取mysql服务的一些状态,这些状态是mysql服务的性能参数!
语法:

SHOW [SESSION | GLOBAL] STATUS

SESSION表示获取当前会话级别的性能参数,GLOBAL表示获取全局级别的性能参数,并且SESSION和GLOBAL可以省略,如果省略不写,默认为SESSION。
b
在这里插入图片描述
参数很多,所以在查找指定参数时,可用以下语法:

SHOW [SESSION | GLOBAL] STATUS LIKE 'status_name';

其中status_name 为状态的参数名称。

实战经验:常用的mysql状态查询

1、QPS(每秒处理的请求数量)

QPS是mysql每秒所执行的sql数量,但不仅限于select 、instert、update和delete语句。

QPS = Questions(or Queries) / seconds

show global status like 'Question%';

在这里插入图片描述

 show global status like 'uptime_since_flush_status';

在这里插入图片描述

计算思路:

先从show global status like ‘Question%’; 得到Question1的数据,经过一段时间后,再计算show global status like ‘Question%’; ,得到Question2的数据。

QPS = (Question2-Question1)/(uptime_since_flush_status2-uptime_since_flush_status1)

Questions和 Queries的区别

在这里插入图片描述
因为 Queries 计数统计的更多,所以理论上 Queries 计数总是大于等于 Questions 计数。

Queries会比Questions 多统计存储过程语句和预准备语句。

2、TPS(每秒处理的事务数量)

TPS指的是每秒处理的事务数量,不包含select语句。

TPS = (Com_commit + Com_rollback) / seconds

show global status like 'Com_commit';

show global status like 'Com_rollback';

字段说明:

Com_commit:事务提交数
Com_rollback:事务回滚数

对于回滚操作非常频繁的数据库,可能意味着应用编写存在问题。

在这里插入图片描述
在这里插入图片描述

计算思路:

先得到** (Com_commit + Com_rollback) ** 的值commit_rollback1,然后经过一段时间后,再得到** (Com_commit + Com_rollback) ** 的值commit_rollback2。
TPS = (commit_rollback2-commit_rollback1)/(uptime_since_flush_status2-uptime_since_flush_status1);

3、key Buffer 命中率

key buffer 命中率代表了​Myisam​类型表的索引cache命中率,命中率的大小直接影响myisam类型表的读写性能。
命中率过低,说明myisam类型表的读写存在问题。
key buffer 命中率实际上包括读命中率和写命中率两种,计算公式如下:

key_buffer_read_hits = (1-key_reads / key_read_requests) * 100%
key_buffer_write_hits = (1-key_writes / key_write_requests) * 100%

show global status like 'key%';

在这里插入图片描述

4、InnoDB Buffer命中率

innodb buffer 所指的是innodb_buffer_pool,也就是用来缓存innodb类型表和索引的内在空间。
命中率过低,说明innodb类型表的读写存在问题。
计算公式:
innodb_buffer_read_hits = (1 - innodb_buffer_pool_reads / innodb_buffer_pool_read_requests) * 100%

show global  status like 'innodb_buffer_pool_read%';

在这里插入图片描述

5、query cache命中率

query cache 是mysql的查询cache,在my.cnf配置文件若打开,则可以对查询过的语句结果进行cache。
对于一些用户数不高或一次性统计平台建议关闭查询缓存。
若开启query cache,则对query cache 命中率进行监控也是需要的,它可以告诉我们是数据库是否在正确使用query cache。
计算公式:
query_cache_hits =(Qcache_hits/(Qcache_hits+Qcache_inserts))* 100%;

show global status like 'Qcache%';

在mysql5中,引入了query-cache的功能,query-cache默认是关闭的。
mysql建议我们用第三方的缓存技术,而不是用mysql本身的 query-cache去缓存数据,在mysql8也移除了query-cache

6 、table_cache(table_open_cache) 命中率

table_cache是一个非常重要的MySQL性能参数,table_cache主要用于设置table高速缓存的数量。在5.1.3之后的版本中叫做table_open_cache
由于每个客户端连接都会至少访问一个表,因此此参数的值与max_connections有关。
当mysql访问某个表时,若表缓存空间还有空间,则将该表就被打开并将数据放入其中,下次访问此表时可以更快的访问表的内容。
通过查峰值时间的状态值open_tables 和 opened_tables可以决定是否需要增加table_cache值。
需要注意的是table_cache设置很太高,可能会造成文件描述符不足,从而造成性能不稳定或是连接失败。

建议:状态量open_tables与opened_tables之间的比率要大于80%

open_tables与opened_tables之间的比率过低,则代表table cache设置过小。

show global status like 'open%_tables';

在这里插入图片描述
查看table_open_cache的值:

show global variables like 'table_open_cache';

修改table_open_cache 的值,方式如下:

  • 方式一:可以在my.ini或my.cnf里修改参数table_open_cache 的值。要重启mysql服务。
  • 方式二:在SET GLOBAL table_open_cache= 2000;这种方式不需要重启mysql服务。MySQL重启后会失效。
6、thread cache命中率

在mysql中,为了尽可能提高客户端连接的过程,实现 了一个thread cache池,将空闲的连接线程存放在其中,而不是请求完成后销毁,当有新的连接请求的时候,mysql首先检查thread cache是否存储空闲的连接线程,如果存在则取出来直接使用,如果没有空闲连接线程,才创建新的线程。
thread cache命中率能直接反应出系统参数thread_cache_size设置是否合理。一个合理的read_cache_size参数能够节约大量创建新连接时所需要消耗的资源。正常来说,​thread cache命中率在90% 以上才算合理​。

计算公式:

thread_cache_hits = (1- threads_created/connections) * 100 %;

show global status like 'Thread%';
show global status like 'Connections';

在这里插入图片描述
在这里插入图片描述
参数说明:

  • threads_created:表示创建过的线程数,很明显,threads_created过大,表明mysql服务器一直在创建线程,这也是比较耗资源,说明服务器不健康
  • Connections:连接MySQL服务器的次数。
优化

如果​thread cache命中率低于90%
查看thread_cache_size 的大小:

show global variables like 'thread_cache_size';

在这里插入图片描述
适当增加配置文件中thread_cache_size值,在my.cnf文件中直接加上thread_cache_size=64。
重启Mysql服务,配置生效。

或者执行下面这个命令,这种方式不需要重启mysql服务。MySQL重启后会失效。

set global thread_cache_size=30;
7、tmp table相关状况分析

tmp table 主要用于监控mysql使用临时表的量是否过多,是否有临时表过大而不得不从内存中换出到磁盘文件中

show global status like 'created_tmp%';

在这里插入图片描述

参数说明:

Created_tmp_disk_tables:为临时表过大无法在内存中完成,而不得不使用磁盘的次数。
若create_tmp_tables比较多,则可能排序句子过多,或者可能是连接方式不是很优化。
而如果是create_tmp_dis_table/create_tmp_tables比率过高,如超过10%,则需要考虑tmp_table_size参数是否需要调整大些。
建议tmp_table_size与max_heap_table_size需要设置成一样大。
在my.cnf文件中直接加上/调整tmp_table_size 的值。重启Mysql服务,配置生效。

或者执行下面这个命令,这种方式不需要重启mysql服务。MySQL重启后会失效。

set global tmp_table_size=自定义;

查看生效的配置:

show global variables like 'tmp_table_size';
show global variables like 'max_heap_table_size';

在这里插入图片描述
在这里插入图片描述

8、binlog cache

若打开binlog日志功能,则需要考虑binlog cache问题。binlog不是一有数据就写到binlog中,而是先写入到binlog cache中,再写入到binlog中。
Binlog_cache_disk_use为binlog使用硬盘使用量, Binlog_cache_use 为binlog已使用的量。若 Binlog_cache_disk_use大于0,则说明binlog_cache不够用,需要调大 binlog_cache_size大小。

show status like 'binlog_cache%';

在这里插入图片描述
在my.cnf文件中直接加上/调整binlog_cache_size 的值。重启Mysql服务,配置生效。

或者执行下面这个命令,这种方式不需要重启mysql服务。MySQL重启后会失效。

set global binlog_cache_size=自定义;

查看生效的配置:

show global variables like 'binlog_cache_size';

在这里插入图片描述

9、innodb_log_waits
show status like 'innodb_log_waits';

Innodb_log_waits值不等于0的话,表明 innodb log buffer 因为空间不足而等待。需要增加innodb_log_buffer_size的值,适当的增加不会造成内存不足的问题。
在这里插入图片描述
在my.cnf文件中直接加上/调整innodb_log_buffer_size 的值。重启Mysql服务,配置生效。

或者执行下面这个命令,这种方式不需要重启mysql服务。MySQL重启后会失效。

set global innodb_log_buffer_size=自定义;

查看生效的配置:

show global variables like 'innodb_log_buffer_size';

在这里插入图片描述

10、锁状态

mysql的锁有表锁和行锁,myisam最小锁为表锁,innodb最小锁为行锁,可以通过以下命令获取锁定次数、锁定造成其他线程等待次数,以及锁定等待时间信息。

 show status like '%lock%';

Table_locks_waited/Table_locks_immediate 的比值比较大的话,说明表锁造成的阻塞比较严重。可能需要调整Query语句,或者更改存储引擎,亦或者需要调整业务逻辑。

而Innodb_row_lock_waits较大,则说明Innodb的行锁也比较严重,且影响了其他线程的正常处理。
造成Innodb行锁严重的原因可能是Query语句所利用的索引不够合理(Innodb行锁是基于索引来锁定的),造成间隙锁过大。

三、总结

本文介绍了什么是SHOW STATUS,以及如何使用SHOW STATUS。分享了10个常用的mysql状态查询:

  • QPS(每秒Query量)
  • TPS(每秒事务数)
  • key Buffer 命中率
  • InnoDB Buffer命中率
  • query cache命中率
  • table_cache(table_open_cache) 命中率
  • tmp table相关状况分析
  • binlog cache
  • innodb_log_waits
  • 锁状态

所以,嗯,这题的答案选。。评论区大声告诉虚竹哥。

四、参考

MySQL进阶技能树>查询优化> SHOW STATUS
如何计算 MySQL 的 QPS/TPS
MySQL调试–show status

五、粉丝福利

在这里插入图片描述
在这里插入图片描述

福利0

虚竹哥直接送1本好书,点赞数最高的好评~

  • 点赞数最高的好评送书:此文章的点赞数最高的好评送一本实体书《Java核心技术》(卷一或卷二 自选一本)

  • 统计截止时间:2023/08/10 19:00:00

福利1

虚竹哥直接送2本好书,参与好评送书~

  • 参与好评送书:随机抽取2位幸运读者,2位幸运读者各送一本实体书《Java核心技术》(卷一或卷二 自选一本)

  • 统计截止时间:2023/08/10 19:00:00

福利2

来虚竹哥送书的朋友圈点赞,点赞送书~
虚竹哥开放好友位 :传送门–》

  • 第8个,第88个好友点赞的,2位幸运读者各送一本实体书《Java核心技术》(卷一或卷二 自选一本)
  • 统计截止时间:2023/08/10 19:00:00

请中奖的读者统计截止时间过后7天内私信虚竹哥收货地址,过期奖励作废哈!

我是虚竹哥,我们明天见~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/68537.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

flutter相关URL schemes

先看效果 使用 url_launcher库 做唤起其他app操作 url_launcher | Flutter Package 配置 安卓 flutter 项目目录下的 android\app\src\main\AndroidManifest.xml 如果不配置的话 有些手机就打不开app <queries><!-- If your app checks for SMS support --><…

Web前端之NodeJS、Vue

文章目录 一、Babel转码器1.1 Babel安装流程1.2 Babel命令行转码 二、Promise对象三、测试方式四、Vue&#xff08;渐进式JS框架&#xff09;4.1 准备4.2 创建一个项目4.3 运行一个项目 五、模板语法5.1 文本5.2 原始html5.3 属性Attribute5.4 使用JavaScript表达式 六、条件渲…

禁止别人调试自己的前端页面代码

为啥要禁止&#xff1f; 由于前端页面会调用很多接口&#xff0c;有些接口会被别人爬虫分析&#xff0c;破解后获取数据 为了 杜绝 这种情况&#xff0c;最简单的方法就是禁止人家调试自己的前端代码 无限 debugger 前端页面防止调试的方法主要是通过不断 debugger 来疯狂输…

chatGPT应用于房地产行业

作为 2023 年的房地产专业人士&#xff0c;您无疑认识到技术对行业的重大影响。近年来&#xff0c;一项技术进步席卷了世界——人工智能。人工智能彻底改变了房地产业务的各个方面&#xff0c;从简化管理任务到增强客户互动。 在本文中&#xff0c;我们将探讨几种巧妙的人工智…

CEC2013(MATLAB):能量谷优化算法EVO求解CEC2013的28个函数

一、能量谷优化算法EVO 能量谷优化算法&#xff08;Energy valley optimizer&#xff0c;EVO&#xff09;是MahdiAzizi等人于2023年提出的一种新颖的元启发式算法&#xff0c;其灵感来自关于稳定性和不同粒子衰变模式的物理原理。能量谷优化算法&#xff08;Energy valley opt…

spss什么是描述性分析,以及如何去处理。

描述性分析是数据分析的第一步&#xff0c;是了解和认识数据基本特征和结构的方法&#xff0c;只有在完成了描述性统计分析&#xff0c;充分的了解和认识数据特征后&#xff0c;才能更好地开展后续更复杂的数据分析。因此&#xff0c;描述性分析是开展数据分析过程中最基础且必…

Idea添加mybatis的mapper文件模版

针对Java开发人员&#xff0c;各种框架的配置模版的确是需要随时保留一份&#xff0c;在使用的时候&#xff0c;方便复制粘贴&#xff0c;但是也依然不方便&#xff0c;我们可以给开发工具&#xff08;IDE&#xff09;中添加配置模版&#xff0c;这里我介绍下使用idea开发工具&…

高忆管理:今年来尚未有公司递表,香港SPAC市场为何“熄火”?

香港SPAC上市准则敞开之后&#xff0c;从第一家公司上市到现在已经有1年多的时刻。&#xff08;【深度】王石、李宁、卫哲争相发起建立SPAC&#xff0c;香港版“上市盲盒”会火吗&#xff1f; 界面新闻了解到&#xff0c;今年以来&#xff0c;香港SPAC并没有新动态&#xff0c;…

数据链路层 -帧结构

帧结构 802.3 有线网卡的帧格式802.11 无线网卡的帧格式 802是指一个国际标准委员会 IEEE 802 帧头主要包括三个部分&#xff1a; 目标MAC&#xff08;6个字节&#xff09;源MAC &#xff08;6个字节&#xff09;类型 &#xff08;包含两种类型&#xff1a;0x0800【IP协议】 …

麻省理工学院利用水泥和炭黑制造出超级电容器

麻省理工学院的研究人员展示了一种使用低成本水泥和炭黑的制造的超级电容器&#xff0c;这一发明可能会彻底颠覆可再生能源的存储。 ​为了解决太阳能、风能和潮汐能等间歇性和非周期性电源的普及问题&#xff0c;实用并且廉价的电力储存技术一直是重要的环节。MIT的研究人员最…

vue中全局状态存储 pinia和vuex对比 pinia比vuex更香 Pinia数据持久化及数据加密

前言 毕竟尤大佬都推荐使用pinia&#xff0c;支持vue2和vue3&#xff01; 如果熟悉vuex&#xff0c;花个把小时把pinia看一下&#xff0c;就不想用vuex了 支持选项式api和组合式api写法pinia没有mutations&#xff0c;只有&#xff1a;state、getters、actionspinia分模块不…

TartanVO: A Generalizable Learning-based VO 论文阅读

论文信息 题目:TartanVO: A Generalizable Learning-based VO 作者&#xff1a;Wenshan Wang&#xff0c; Yaoyu Hu 来源&#xff1a;ICRL 时间&#xff1a;2021 代码地址&#xff1a;https://github.com/castacks/tartanvo Abstract 我们提出了第一个基于学习的视觉里程计&…

妙盈面试(部分)

算法题1&#xff0c;二分查找即可&#xff1a; git rebase算法题2&#xff0c;求二叉树两结点的最小公共祖先 搞笑的是&#xff0c;第2道算法题我刚开始做&#xff0c;黑屏了两秒钟&#xff0c;当时其实腾讯会议软件已经崩溃了&#xff0c;但是我没注意到而是继续做题。等到做…

Stable Diffusion - 常用的负向提示 Embeddings 解析与 坐姿 (Sitting) 提示词

欢迎关注我的CSDN&#xff1a;https://spike.blog.csdn.net/ 本文地址&#xff1a;https://spike.blog.csdn.net/article/details/132145248 负向 Embeddings 是用于提高 StableDiffusion 生成图像质量的技术&#xff0c;可以避免生成一些不符合预期的图像特征&#xff0c;比如…

推出稳定代码:人工智能辅助编码的新视野

推荐&#xff1a;使用 NSDT场景编辑器 快速助你搭建可二次编辑的3D应用场景 在不断发展的软件开发环境中&#xff0c;对效率和可访问性的追求导致了各种工具和平台的创建。最新的创新之一是StableCode&#xff0c;这是Stability AI的大型语言模型&#xff08;LLM&#xff09;生…

整理mongodb文档:改

个人博客 整理mongodb文档:改 求关注&#xff0c;求批评&#xff0c;求进步 文章概叙 本文主要讲的是mongodb的updateOne以及updateMany&#xff0c;主要还是在shell下进行操作&#xff0c;也讲解下主要的参数upsert以及更新的参数。 数据准备 本次需要准备的数据不是很多…

怎样做接口测试:从入门到精通的指南

怎样做接口测试&#xff1a;从入门到精通的指南 为什么接口测试如此重要&#xff1f; 接口测试在软件开发过程中扮演着关键的角色。它确保不同系统、组件或服务之间的无缝集成和通信。 接口测试的基本概念 接口测试是一种验证软件系统组件之间相互连接的过程。它主要关注数据…

SpringBoot 整合Druid

集成Druid Druid简介 Java程序很大一部分要操作数据库&#xff0c;为了提高性能操作数据库的时候&#xff0c;又不得不使用数据库连接池。 Druid 是阿里巴巴开源平台上一个数据库连接池实现&#xff0c;结合了 C3P0、DBCP 等 DB 池的优点&#xff0c;同时加入了日志监控。 D…

【CSS】背景图定位问题适配不同机型

需求 如图, 实现一个带有飘带的渐变背景 其中头像必须显示飘带凹下去那里 , 需要适配不同的机型, 一不下心容易错位 实现 因为飘带背景是版本迭代中更新的, 所以飘带和渐变背景实则两个div 飘带切图如下 , 圆形部分需要契合头像 <view class"box-bg"><…

C++内存管理(new与delete)

这篇文章的主要内容是new与delete的由来&#xff0c;使用new与delete对C堆内存进行管理&#xff0c;(malloc、free)与(new、delete)的区别。希望对C爱好者有所帮助&#xff0c;内容充实且干货&#xff0c;点赞收藏防止找不到&#xff01; 更多C优质内容跳转&#xff1a; 重生之…