首页
题库
公司真题
专项练习
面试题库
在线编程
面试
面试经验
AI 模拟面试
简历
求职
学习
基础学习课
实战项目课
求职辅导课
专栏&文章
竞赛
搜索
我要招人
发布职位
发布职位、邀约牛人
更多企业解决方案
AI面试、笔试、校招、雇品
HR免费试用AI面试
最新面试提效必备
登录
/
注册
神让我捡漏
门头沟学院 测试开发
发布于广东
关注
已关注
取消关注
m
@Java抽象带篮子_转大模型应用开发版:
Mysql调优攻略大全(建议收藏)
0.前言 建议与我的八股专栏的jvm八股配合使用。觉得本贴有用的收藏点个赞评论下送朵花什么的吧。下面我会让你看看什么是传说中的mysql调优(八股面试吹b版)。 打个小广告 我的架构设计专栏:https://www.nowcoder.com/creation/manager/columnDetail/0ybvLm 我的八股专栏:https://www.nowcoder.com/creation/manager/columnDetail/j8ZZk0 内有详细苍穹外卖话术哦! 为什么我要开个八股专栏? 一方面有感于现在面试找工作对八股的要求之高,一方面有感于市面上的一些八股资料又乱又复杂难懂,所以我决定自己结合各种市面上优秀的博客、gpt,牛客上的面经和我自己的理解,整合出一份八股资料,我的目标是:让八股文成为真正简单易懂的八股,知识点丰富且浅显易懂,不追求过分的深入,但一定重点层次分明(如果想深入了解知识点的话还是建议自己认真看看javaguide和小林coding,但其实我就是看了他们的全部博客取精华精炼部分融入我的专栏。。。),一句话就是我的八股专栏主打一个面试速成,一点超纲的知识点都不会有,因为我自己也用这份笔记准备秋招。。。 1.怎么定位慢查询? 2种方法·: 运维监控工具Slywalking 我们当时做压测的时候有的接口非常的慢,接口的响应时间超过了2秒以上,因为我们当时的系统部署了运维的监控系统Skywalking ,在展示的报表中可以看到是哪一个接口比较慢,并且可以分析这个接口哪部分比较慢,这里可以看到SQL的具体的执行时间,所以可以定位是哪个sql出了问题 mysql慢查询日志 2.怎么分析慢sql? 通过EXPLAIN分析SQL执行计划 ALL:表示全表扫描,需要遍历全表来找到对应的行。 possible_keys:可能使用到的索引。 key:实际使用到的索引。 key_len:当前使用的索引的长度。 ref:关联id等信息。 rows:查找到记录所扫描的行数。 filtered:查找到所需记录占总扫描记录数的比例。 Extra:额外的信息。 通过Show Profile分析SQL执行性能 上述通过 EXPLAIN 分析执行计划,仅仅是停留在分析SQL的外部的执行情况,如果我们想要深入到MySQL内核中,从执行线程的状态和时间来分析的话,这个时候我们就可以选择Profile。 Profile除了可以分析执行线程的状态和时间,还支持进一步选择ALL、CPU、MEMORY、BLOCK IO、CONTEXT SWITCHES等类型来查询SQL语句在不同系统资源上所消耗的时间。以下是相关命令的注释: SHOW PROFILE [type [, type] ... ][FOR QUERY n][LIMIT row_count [OFFSET offset]]type参数:| ALL:显示所有开销信息| BLOCK IO:阻塞的输入输出次数| CONTEXT SWITCHES:上下文切换相关开销信息| CPU:显示CPU的相关开销信息 | IPC:接收和发送消息的相关开销信息| MEMORY :显示内存相关的开销,目前无用| PAGE FAULTS :显示页面错误相关开销信息| SOURCE :列出相应操作对应的函数名及其在源码中的调用位置(行数) | SWAPS:显示swap交换次数的相关开销信息 Show Profiles只显示最近发给服务器的SQL语句,默认情况下是记录最近已执行的15条记录,我们可以重新设置profiling_history_size增大该存储记录,最大值为100。 获取到Query_ID之后,我们再通过Show Profile for Query ID语句,就能够查看到对应Query_ID的SQL语句在执行过程中线程的每个状态所消耗的时间了: 通过以上分析可知:SELECT COUNT(*) FROM order; SQL语句在Sending data状态所消耗的时间最长,这是因为在该状态下,MySQL线程开始读取数据并返回到客户端,此时有大量磁盘I/O操作。 3.怎么用explain分析sql执行计划 我们可以使用 EXPLAIN 命令来分析 SQL 的 执行计划 。 1.什么是执行计划 执行计划 是指一条 SQL 语句在经过 MySQL 查询优化器 的优化会后,具体的执行方式。 通过 EXPLAIN 的结果,可以了解到如数据表的查询顺序、数据查询操作的操作类型、哪些索引可以被命中、哪些索引实际会命中、每个数据表有多少行记录被查询等信息。 2.执行计划常用字段 MySQL 为我们提供了 EXPLAIN 命令,来获取执行计划的相关信息。 需要注意的是,EXPLAIN 语句并不会真的去执行相关的语句,而是通过查询优化器对语句进行分析,找出最优的查询方案,并显示对应的信息。 执行计划有12个字段组成,常用的有: 1.type表示查询表连接类型**,查看索引执行情况的一个重要指标。以下性能从好到坏依次:system > const > eq_ref > ref > ref_or_null > index_merge > unique_subquery > index_subquery > range > index > ALL system:这种类型要求数据库表中只有一条数据,是const类型的一个特例,一般情况下是不会出现的。 const:通过一次索引就能找到数据,一般用于主键或唯一索引作为条件,这类扫描效率极高,,速度非常快。基于主键或唯一索引唯一值查询,最多返回一条结果,比eq_ref略好。 eq_ref:常用于主键或唯一索引扫描,一般指使用主键的关联查询 ref : 常用于非主键和唯一索引扫描。 ref_or_null:这种连接类型类似于ref,区别在于MySQL会额外搜索包含NULL值的行 index_merge:使用了索引合并优化方法,查询使用了两个以上的索引。 unique_subquery:类似于eq_ref,条件用了in子查询 index_subquery:区别于unique_subquery,用于非唯一索引,可以返回重复值。 r
点赞 13
评论 3
全部评论
推荐
最新
楼层
暂无评论,快来抢首评~
相关推荐
04-08 11:09
已编辑
门头沟学院 Java
27届-暑期实习-携程-一面
🕐面试时间:26.4.3-一个小时💻面试岗位:Java开发❓面试问题:自我介绍介绍实习的慢SQL优化如何看待慢SQL排查与优化工作的主动性(被动救火优化)?是否存在更前置的风险防控思路?当已知某条SQL执行不符合预期(如要求优化至100ms以内),您的系统化排查与优化思路是什么?聚簇索引与普通索引的核心区别,以及各自典型的应用场景。如果利用AI自动化识别项目中因索引设计不当导致的回表性能问题,技术实现思路是怎样的?反问业务和流程聊AI和如何与工作结合🙌面试感想:问问题也就是25分钟,后续就是反问和闲聊了,无手撕。
查看6道真题和解析
点赞
评论
收藏
分享
昨天 16:34
已编辑
门头沟学院 Java
27届-暑期实习-网易-平台研发-一面凉经
💻面试岗位:平台研发❓面试问题:1、自我介绍2、手撕:模拟文件路径缩略符、3、求TopK最小值,一开始使用快速选择,然后再来个场景题:大数据量下求TopK如何实现?4、介绍下Http协议5、TCP粘包问题6、逻辑地址和物理地址的区别7、Cookie是什么8、TCP三次握手,为什么不两次握手9、设计HTTP协议10、同ip同端口。网址不同,怎么让两个网址访问同一个端口的时候分辨是哪个网址请求的?🙌面试感想:项目一点没问,他说他们项目组是用python写代码的,一面挂。
发面经攒人品
点赞
评论
收藏
分享
03-08 18:11
门头沟学院 Java
26届Java简历求评价
目前只能约到小公司,求大神指导
Java抽象小篮子:
海投就完事了,简历没什么问题,最大问题是学历
点赞
评论
收藏
分享
03-16 07:53
门头沟学院 嵌入式工程师
兄弟们这简历真不真实,有没有问题😭
点赞
评论
收藏
分享
04-09 22:35
西南石油大学 数据分析师
招银网络面试
实习经历拷打这个功能(单点登录)具体是做什么的?“Ticket”是什么?里面包含了哪些信息?Token存储在哪里?后端如何进行身份认证和校验?Token是明文传输的吗?系统是否会记录用户的登录状态(如登录时间、超时)到数据库?如果没有,如何判断Token是否过期?在拦截器中使用ThreadLocal存储用户信息,目的是什么?ThreadLocal是线程内共享的。如果一个用户连续发起两个请求,它们能被同一个ThreadLocal处理吗?为什么?一个请求处理结束后,是否需要手动删除ThreadLocal中的数据?为什么?八股HashMap是线程安全的吗?请举例说明一个HashMap线程不安全的场景...
查看11道真题和解析
点赞
评论
收藏
分享
评论
点赞成功,聊一聊 >
点赞
收藏
分享
评论
提到的真题
返回内容
全站热榜
更多
1
...
翼支付近两年真实体验
4511
2
...
过来人聊聊对招商银行数字金融训练营的感受
3845
3
...
美团前端考察AI coding出的题是周报生成?
2155
4
...
字节剪映123面全面经
2082
5
...
工作一年,聊聊对Agent开发的感受
1251
6
...
2026春招北京奈亚信息技术有限公司
1173
7
...
因为上班玩手机被开除😭
932
8
...
灵犀互娱 游戏客户端开发 一面
853
9
...
恒生电子一面只面了20min
700
10
...
字节面试 抽到hot100原题 翻车
552
创作者周榜
更多
正在热议
更多
#
父母问你工作找得怎么样,怎么回
#
9456次浏览
127人参与
#
面试被问期望薪资时该如何回答
#
390045次浏览
2178人参与
#
厦门银行科技岗值不值得投
#
19726次浏览
427人参与
#
哪些公司面试还在问八股?
#
4698次浏览
54人参与
#
想从事Agent应该学习哪些技术?
#
1968次浏览
60人参与
#
从投递到OC,你用了多久
#
9474次浏览
79人参与
#
你的秋招第一面感觉怎么样
#
146967次浏览
821人参与
#
有哪些公司在面试时考察AICoding?
#
3401次浏览
45人参与
#
什么人最适合大厂?
#
4722次浏览
41人参与
#
HR面都在聊什么?
#
3303次浏览
44人参与
#
AI时代还有必要刷leetcode吗?
#
1906次浏览
30人参与
#
你觉得机械有必要实习吗
#
82266次浏览
515人参与
#
哪一刻你突然觉得实习“有点值了”
#
7406次浏览
54人参与
#
一人一道大厂面试题
#
134215次浏览
1334人参与
#
kpi面有什么特征
#
106223次浏览
506人参与
#
硬件人的简历怎么写
#
341383次浏览
3121人参与
#
通信硬件2023笔面经
#
53782次浏览
322人参与
#
总结:哪家公司最喜欢泡池子
#
172077次浏览
620人参与
#
稳定和高薪机械人更看重哪个?
#
582603次浏览
5568人参与
#
四大天坑是哪四家?
#
113899次浏览
246人参与
#
计算机有哪些岗位值得去?
#
395765次浏览
2942人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务