文档章节

MySQL优化

mywd
 mywd
发布于 2017/08/19 14:22
字数 1060
阅读 32
收藏 1

一、目的

  1. 解决由于慢查询造成的页面加载慢或者无法加载
  2. 解决阻塞造成数据无法提交

二、优化方式

  • SQL 及索引优化

这种方式是我们平时使用的最多也是代价最低效果最为明显的一种方式

  • 定位哪些SQL需要优化

    • 开启mysql慢查日志

            在MySQL客户端中输入命令:

                show variables like '%quer%';

                -slow_query_log是否记录慢查询。用long_query_time变量的值来确定“慢查询”。

                -slow_query_log_file慢日志文件路径

                -long_query_time慢日志执行时长(秒),超过设定的时间才会记日志

            Linux:

                在/etc/my.cnf配置文件的[mysqld]选项下增加:

                slow_query_log=TRUE

                slow_query_log_file=/usr/local/mysql/slow_query_log.txt

                long_query_time=3

            Windows:

                在my.ini配置文件的[mysqld]选项下增加:

                slow_query_log=TRUE

                slow_query_log_file=c:/slow_query_log.txt

                long_query_time=3

  • 慢查日志所包含的内容

        1、执行SQL的主机信息

            

         2、SQL的执行信息

            

         3、SQL执行时间    

            

          4、SQL的内容

            

  • 慢查日志的分析工具

            1、mysqldumpslow

                 mysqldumpslow [opts] [logs]
                    logs -具体的慢查日志
                    opts  -t  分析的条数  -s排列方式

              结果:

                

            2、pt-query-digest  

                pt-query-digest  [opts] [logs]

                还可以定义慢查询结果输出到文件:

                

                输出查询结果到数据库表:

                

  • 通过慢查日志发现有问题的SQL

                1、查询次数多且每次查询占用时间长的SQL

                        通常为pt-query-digest分析的前几个查询

                2、IO大的SQL

                        注意pt-query-digest分析中的Rows examine项数值大的

                3、未命中索引的SQL

                        注意pt-query-digest分析中的Rows examine 和Rows send的对比

  • 使用explain查询SQL的执行计划

                

                

                

  • 常见的SQL优化

            1、Max()的优化

              例如:  

                        为max()字段添加索引

                        

                        

                        只查询索引,不用查询表,应为索引是有序的与数据量无关,大大加快了查询速度

            2、Count()

                        count(*)时会包含为null的值,count(XX)不包含xx为null时的值

            3、子查询的优化

                       通常情况下需要把子查询优化为join查询,在优化时需要注意关联键是否有一对多的关系,要注意重复数据

            4、limit   

                        limit常用于分页处理,时常会伴随order by使用,因此大多时候会使用Filesorts造成大量的IO问题,通常使用有索引的列或者主键进行order by操作来解决

  • 选择合适的列建立索引

            在where从句,group by从句,order by从句,on从句出现的列建立索引、索引字段越小越好、离散度大(具体就是字段数值相差越大离散度就越大)的列放到联合索引的前面

  • 索引的维护和优化

            1、重复索引、冗余索引

                相同的列以相同的顺序建立的同类型的索引

                    

                多个索引的前缀列相同,或是在联合索引中包含了主键的索引

                    

                主键索引会自动添加上

            2、优化方式

                使用pt-duplicate-key-checker工具检查重复及冗余索引

                

                结果:

                    

                查找未使用的索引:

                    

  • 数据库表结构优化

  • 选择合适的数据类型

            

           例如:

             

            

  • 表的范式化设计

            范式化一般是指第三设计范式,也就是要求数据表中不存在非关键字段对任意候选关键字段的传递函数依赖则符合第三范式

  • 表的反范式化

            为了查询效率的考虑把原本符合第三范式的表适当的增加冗余,已达到优化查询效率的额目的,反范式化是一种以空间来换时间的操作

  • 表的垂直拆分

            

  • 表的水平拆分

            为了解决单表的数据量过大查询效率低的问题,水平拆分表的每一个表的结构都是完全一致的

            缺点:跨分区表进行数据查询、统计及后台报表的操作

  • 系统配置优化

  • 操作系统的配置优化

            1、

                2、

  • MySQL配置优化

            1、MySQL配置文件位置

                

            2、重要参数

                

                

                

                

                

            3、第三方配置工具

                 如果不清楚具体如何配置,可以通过第三方配置工具快捷帮你配置

                     https://tools.percona.com/wizard

  • 硬件优化

            

© 著作权归作者所有

共有 人打赏支持
mywd
粉丝 3
博文 9
码字总数 4255
作品 0
加载中

评论(1)

nikeodong
nikeodong
污杨王牛逼...:smile:

暂无文章

laravel 微信支付

1.composer加载laravel微信支付第三方文件 composer require "overtrue/laravel-wechat:~4.0" composer require simplesoftwareio/simple-qrcode 1.3.* //composer生成二维码文件 2.改confi......

vio小黑
22分钟前
1
0
学习设计模式——抽象工厂模式

1. 认识抽象工厂模式 1. 定义:提供一个创建一系列相关或互相依赖的对象的接口,而无需指定它们具体的类。 2. 组成结构: AbstractFactory:抽象工厂类,定义创建一系列对象的操作接口 Fact...

江左煤郎
22分钟前
2
0
ES6的let块级作用域和变量不可提升导致一个比较容易出现的错误

今天在写NodeJS代码的时候出现一个变量一直提示未定义,简化后的代码如下: let param = 1;{ console.log(param);} 就在想,不至于啊。不是继承上层的声明吗? 继续看下去,发现原来...

MKjy
29分钟前
2
0
50:nginx访问日记|日记切割|静态文件不记录日记和过期时间

1、nginx访问日记: 日记格式:在主配置文件nginx.conf里搜索log_format; [root@localhost_001 conf]# vim nginx.conflog_format combined_realip '$remote_addr $http_x_forwarded_for ......

芬野de博客
32分钟前
1
0
前后端正常交互的流程

1、评审阶段:产品召集前后端进行需求评审,前后端各自捋清楚自己的业务量以及联调之间工作量,从而进行开发时间评估。 2、开发准备阶段:前后端一起商量需求中需要联调的部分,进行接口的口...

Jack088
33分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部