MySQL问题排查工具介绍
本总结来自美团内部分享,屏蔽了内部数据与工具
知识准备
索引
- 索引是存储引擎用于快速找到记录的一种数据结构
- B-Tree,适用于全键值,键值范围或键最左前缀:(A,B,C): A, AB, ABC,B,C,BC
- 哪些列建议创建索引:WHERE, JOIN , GROUP BY, ORDER BY等语句使用的列
- 如何选择索引列的顺序:
- 经常被使用到的列优先
- 选择性高的列优先:选择性=distinct(col)/count(col)
- 宽度小的列优先:宽度 = 列的数据类型
慢查询
原因
- 未使用索引
- 索引不优
- 服务器配置不佳
- 死锁
- ...
命令
看版本
mysql -V 客户端版本 select version 服务器版本
explain 执行计划,慢查询分析神器
- type
- const,system: 最多匹配一个行,使用主键或者unique进行索引
- eq_ref: 返回一行数据,通常在联接时出现,使用主键或者unique索引(内表索引连接类型)
- ref: 使用key的最左前缀,且key不是主键或unique键
- range: 索引范围扫描,对索引的扫面开始于某一点,返回匹配的行
- index:以索引的顺序进行全表扫描,优点是不用排序,缺点是还要全表扫描
- all: 全表扫描 no no no
- extra
- using index : 索引覆盖,只用到索引,可以避免访问表
- using where: 在存储引擎检索行后再做过滤
- using temporary:使用临时表,通常在使用GROUP BY,ORDER BY 时出现(严禁)
- using filesort: 到非索引顺序的额外排序,当order by col未使到索引时发生(严禁)
- possible_keys: 显示查询可能使用的索引
- key:优化器决定采用哪个索引来优化对该表的访问
- rows:MySQL估算的为了找到所需行要检索的数,优化选择key的参考 (不是结果集的行数)
- key_len: 使用的索引左前缀的长度(字节数),亦可理解为使用了索引中哪些字段
- 定长字段,int占4个字节、date占3个字节、timestamp占4个字节,char(n)占n个字节
- NULL的字段:需要加1个字节,因此建议尽亮设计为NOT NULL
- 变长字段varchar(n),则需要 (n * 编码字符所占字节数 + 2 、)个字节,如utf8编码的, 个字符
占 3个字节,则 度为 n * 3 + 2
- 强制使用索引: USE INDEX (建议)或 FORCE_INDEX (强制)
show 命令
- show status
- 查看select语句的执行数 show global status like 'Com_select';
- 查看慢查询的个数 show global status like 'Slow_queries';
- 表扫描情况 show global status like 'Handler_read%'; Handler_read_rnd_next / com_select > 4000 需要考虑优化索引
- show variables
- 查看慢查询相关的配置 show variables like 'long_query_time';
- 将慢查询时间线设置为2s set global long_query_time=2;
- 查看InnoDB缓存 show variables like 'innodb_buffer_pool_size';
- 查看InnoDB缓存的使用状态 show status like 'Innodb_buffer_pool_%'; 缓存命中率=(1-Innodb_buffer_pool_reads/ Innodb_buffer_pool_read_requests) * 100%;缓存率=(Innodb_buffer_pool_pages_data/ Innodb_buffer_pool_pages_total) * 100%
- SHOW PROFILES;该命令可以trace在整个执行过程中各资源消耗情况(会话级)
- SHOW PROCESSLIST; 查看当前有哪些线程正在运行,并且处在何种状态
- SHOW ENGINE INNODB STATUS; 可用于分析死锁,但需要super权限
MySQL问题排查工具介绍的更多相关文章
- 转 MySQL问题排查工具介绍
原文链接: http://mrchenatu.com/2017/03/24/mysql-tool/ 本总结来自美团内部分享,屏蔽了内部数据与工具 知识准备 索引 索引是存储引擎用于快速找到记录的一种数 ...
- 简要介绍Apache、php、mysql安装和工具介绍
1 安装Apache 网站:www.Apache.org下载相应的Apache,目前下载了近期的:httpd-2.2.15-win32-x86-openssl-0.9.8msi 安装简要步骤如下图: ...
- MySQL之IDE工具介绍及数据备份
一.IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 二.MySQL数据备份 # ...
- MySQL数据库----IDE工具介绍及数据备份
一.IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 二.MySQL数据备份 # ...
- 十三、MySQL之IDE工具介绍及数据备份
一.IDE工具介绍 生产环境还是推荐使用mysql命令行,但为了方便我们测试,可以使用IDE工具 下载链接:https://pan.baidu.com/s/1bpo5mqj 二.MySQL数据备份 # ...
- mysql 开发进阶篇系列 44 物理备份与恢复( 热备份xtrabackup 工具介绍)
一.概述 物理备份和恢复又分为冷备份和热备份.与逻辑备份相比,它最大优点是备份和恢复的速度更快.因为物理备份的原理都是基于文件的cp. 1.1 冷备份 冷备份就是停掉数据库服务.这种物理备份一般很少使 ...
- MySQL Flashback 工具介绍
MySQL Flashback 工具介绍 DML Flashback 独立工具,通过伪装成slave拉取binlog来进行处理 MyFlash 「大众点点评」 binlog2sql 「大众点评(上海) ...
- MySql点点滴滴(一)之可视化工具介绍
以下的文章主要介绍的是10个可以简化开发过程的MySQL工具,其中包括MySQL Workbench.phpMyAdmin.Aqua Data Studio,以及SQLyog与MYSQL Front等 ...
- Android系统性能调优工具介绍
http://blog.csdn.net/innost/article/details/9008691 经作者授权,发表Tieto某青年牛的一篇<程序员>大作. Android系统性能调优 ...
随机推荐
- sqlite性能优化
1.数据库性能上 1.1 批量事务插入,提升数据插入的性能 由于sqlite默认每次插入都是事务,需要对文件进行读写,那么减少事务次数就能简书磁盘读写次数从而获得性能提升. 1.2 单条sql优于多条 ...
- Mysql安装过程中出现apply security settings错误的解决方法
在学习Mysql的过程中,首先要安装Mysql.然而在第一遍安装过程中难免会出现安装错误的时候,当卸载后第二次安装(或者第三次甚至更多次)的时候,往往在安装最后一步会出现apply security ...
- Tensorflow笔记——神经网络图像识别(一)前反向传播,神经网络八股
第一讲:人工智能概述 第三讲:Tensorflow框架 前向传播: 反向传播: 总的代码: #coding:utf-8 #1.导入模块,生成模拟数据集 import t ...
- 告诉你C盘里的每个文件夹都是干什么用的 ! ! !
Documents and Settings是什么文件? 答案: 是系统用户设置文件夹,包括各个用户的文档.收藏夹.上网浏览信息.配置文件等. 补:这里面的东西不要随便删除,这保存着所有用户的文档 ...
- Redux 处理异步 Action
redux-promise-utils What redux-promise-utils 是一个基于 redux-thunk 和 redux-actions 的工具,符合 FSA 规范,方便开发者处理 ...
- Visual Basic 函数速查
Calendar 常数 可在代码中的任何地方用下列常数代替实际值: 常数 值 描述 vbCalGreg 0 指出使用的是阳历. vbCalHijri 1 指出使用的是伊斯兰历法. Color 常数 可 ...
- eclipse报Access restriction: The type 'BASE64Decoder' is not API处理方法
今天从svn更新代码之后,由于代码中使用了BASE64Encoder 更新之后报如下错误: Access restriction: The type ‘BASE64Decoder’ is not A ...
- 在Ubuntu16.04中安装Docker CE
apt-get install apt-transport-https ca-certificates curl software-properties-common curl -fsSL https ...
- 基于python的Appium自动化测试的坑
真的感谢@虫师 这位来自互联网的老师,让我这个原本对代码胆怯且迷惑的人开始学习自动化测试. 一开始搜索自动化测试的时候,虫师的博客园教程都是在百度的前几位的,我就跟着虫师博客园里面的教程学习.后来学s ...
- ios 7.1企业证书无线安装
ios升级到7.1时,企业证书http服务器发布无线安装不能使用,需要使用https服务器. 测试了几种方式 1.测试时自签名https证书测试无效,提示不能连接到服务器 2.使用dropbox共享连 ...