版权声明:本文为博主原创文章,未经博主同意不得转载。 https://blog.csdn.net/Bv5f4b8Peex/article/details/78130845

如今网上的好多mysql优化写的都非常宽泛。没什么实际的价值。今天我们从目的,思路,工具几个方面着重讲一下。

目的:

我们mysql优化的目的是什么呢?

避免数据库连接超时出现5xx错误。

避免慢查询造成页面无法载入。

避免堵塞造成数据无法提交。

我们一般就是从sql和索引,数据库表结构。系统设置,硬件。四个方面来进行优化,而sql和索引以及数据库表结构占领了我们sql优化的大部分内容,是我们优化的基础。

接下来我们就開始搞一波事。

我们连接我们的mysqlserver。然后我们输入命令:

show variables like ‘slow_query_log’;

目的是为了查看我们的慢查询日志是否打开;

http://mmbiz.qpic.cn/mmbiz_png/Vib7BluqnchEI4Sx4qlgqhD5wL5njBxd4sKtTSVb5RCUFqoqsPnKpc9eQeM7aSOcdGj68qoQ0nsiacDfrcQImByQ/640?

wx_fmt=png&wxfrom=5&wx_lazy=1" style="visibility:visible !important;" alt="640?wx_fmt=png&wxfrom=5&wx_lazy=1" />

ok ,非常明显我们的慢查询日志没有打开,那么我们先看一下没有使用索引的sql有没有被日志记录。

show variables like '%log%',然后我们能够看到

我这边是已经开启了的。假设你那里没有开启的话,我们仅仅须要输入命令

set global log_query_not_using_indexes = on;

这一条命令开启就能够了,然后我们指定一下我们的慢查询日志记录的时间。

假设你的mysql 没有设置过的话,这一项的值应该为0,意思就是每次查询都会被记录,可是在生产环境中,假设设置为0的话,那么会在一段时间内产生大量的慢查询日志,占用硬盘空间。

然后我们开启我们的慢查询日志:

set global slow_query_log = on;

wx_fmt=png" />

ok,到了这一步我们的慢查询日志就已经开启了。

ok我这有一个数据库,给大家到时候装上就能够了,首先看一下world数据库:

http://mmbiz.qpic.cn/mmbiz_png/Vib7BluqnchEI4Sx4qlgqhD5wL5njBxd4HmXJO9edwMVoWicaEmwI0H0o9B3hDL0UUnK5tlKeZePTibiaNxfZWZdUw/0?wx_fmt=png" alt="0?

wx_fmt=png" />

ok,一共三张表。我们随便写一个sql语句:

select * from country limit 20;

wx_fmt=png" alt="0?wx_fmt=png" />

好了,我们如今来查看一下我们的慢查询日志。

tail -20  /data/mysql/iZm5ec880z2roqZ-slow.log

wx_fmt=png" />

ok。日志中已经生成了我们刚才写的sql操作的日志,日志中包含了,sql运行的主机信息,sql运行的时间,sql运行的内容,sql运行的信息等。

我们接下来就使用mysql的工具来分析慢查询日志。第一个就是mysqldumpslow

wx_fmt=png" alt="0?wx_fmt=png" />

然后我们使用命令:

mysqldumpslow -t 3 慢查询日志路径 

http://mmbiz.qpic.cn/mmbiz_png/Vib7BluqnchEI4Sx4qlgqhD5wL5njBxd44BiaeyMeHp4YD5srxtXEuIpCTIUPYYSx4f6fsiays8WW2D79c1WtYFYA/0?wx_fmt=png" alt="0?wx_fmt=png" />

        我们也能够使用工具pt-query-digest来分析慢查询日志。这个我明天把软件装上我们再讲,本来想一口气全讲完的,看了看东西还不少。所以我们就分为三部分吧,明天讲sql和索引的优化。后天是系统设置和硬件。一般硬件的配置除非你是专业的DBA不然没多大用处。了解一下就能够了。

【Mysql优化三章】第一章的更多相关文章

  1. MySQL优化三(InnoDB优化)

    body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...

  2. 高性能MySQL(第4版) 第一章 MySQL架构 读书笔记

    这本书去年11月出的,今年中文版也出了,并且直接上了微信读书,之后有空就读一读,分享下读书笔记~ 原文内容比较充实,建议有时间可以读一下原文. 第一章主要是个概览. MySQL的逻辑架构 默认情况下, ...

  3. Java 线程第三版 第一章Thread导论、 第二章Thread的创建与管理读书笔记

    第一章 Thread导论 为何要用Thread ? 非堵塞I/O      I/O多路技术      轮询(polling)      信号 警告(Alarm)和定时器(Timer) 独立的任务(Ta ...

  4. Java 螺纹第三版 第一章Thread介绍、 第二章Thread创建和管理学习笔记

    第一章 Thread导论 为何要用Thread ? 非堵塞I/O      I/O多路技术      轮询(polling)      信号 警告(Alarm)和定时器(Timer) 独立的任务(Ta ...

  5. ASP.NET自定义控件组件开发 第一章 第三篇 第一章的完结篇

    ASP.NET自定义控件组件开发 第一章 第三篇   第三篇:第一章的完结篇 系列文章链接: ASP.NET自定义控件组件开发 第一章 待续 ASP.NET自定义控件组件开发 第一章 第二篇 接着待续 ...

  6. ASP.NET自定义控件组件开发 第一章 第一章:从一个简单的控件谈起

    第一章:从一个简单的控件谈起 系列文章链接: ASP.NET自定义控件组件开发 第一章 待续 ASP.NET自定义控件组件开发 第一章 第二篇 接着待续 ASP.NET自定义控件组件开发 第一章 第三 ...

  7. python全栈开放实践第三版第一章的练习题完成情况

    练习题: 1.简述编译型与解释型语言的区别,且分别列出你知道哪些语言属于编译型,哪些数以解释型.1 编译型:只须编译一次就可以把源代码编译成机器语言,后面的执行无须重新编译,直接使用之前的编译结果就可 ...

  8. Python 学习第三部分函数——第一章函数基础

    函数是python 为了代码最大程度的重用和最小代码冗余而提供的最基本的程序结构.使用它我们可以将复杂的系统分解为可管理的部件. 函数相关语句 def...          创建一个对象并将其赋值给 ...

  9. mysql挖掘与探索------第一章(简介)

    一.数据库简介: 1按照数据库发展时间,主要出现下面几个类型的数据库系统: a 网状型数据库 b 层次型数据库 c 关系型数据库 d 面向对象数据库 上面4中数据库系统中,关系型数据库使用最为广泛.面 ...

随机推荐

  1. codeforcess水题100道

    之所以在codeforces上找这100道水题的原因是为了巩固我对最近学的编程语言的掌握程度. 找的方式在codeforces上的PROBLEMSET中过的题最多的那些题里面出现的最前面的10个题型, ...

  2. 八款值得尝试的精美的 Linux 发行版(2017 版)

    八款值得尝试的精美的 Linux 发行版(2017 版) 2017年10月18日 • Linux • 295 views • 暂无评论 在这篇文章中,将会列出让一些令 Linux 用户印象最深刻且精美 ...

  3. django rest framwork教程之 viewsets和routers

    ViewSets 和Routers REST框架包括一个用于抽象处理的ViewSets,允许开发人员集中精力对API的状态和交互进行建模,并根据常见约定自动处理URL构造. Viewset 类和 Vi ...

  4. IOS设计模式第五篇之装饰设计模式的代理设计模式

    版权声明:原创作品,谢绝转载!否则将追究法律责任. 代理: 另一个装饰设计模式,代理,是一个代表或者协调另一个对象的行为机制.例如当你用一个tableView,你必须实现他里面的一个tableView ...

  5. Makefile 链接静态库

    Linux的静态库是以.a结尾的,要连接静态库有两种方法,一种是在编译命令最后直接加上库路径/库名称. 例如你的库在绝对目录/lib/libtest.a下面你就可以这样来编译$(CC) $(CFLAG ...

  6. echarts - 特殊需求实现代码汇总之【柱图】篇

    其实包括饼图.线图在内,和柱图都一样的感觉,他们的配置项基本也是对应的那几个,所以想实现某些相似的效果,只要找到对应的属性就可以了. 1.柱图渐变色设置 还记得上篇线图中的实现是在areaStyle的 ...

  7. linux学习路线图

  8. cocos2d-x学习之旅(五):1.5 使用eclipse编译cocos2d-x示例项目,创建cocos2d-x android项目并部署到真机

    今天将cocos2d-x的示例项目tests编译到android真机运行,以及如何创建cocos2d-x的android项目. 打开cocos2d-x的tests项目,路径为:D:\cocos2d-x ...

  9. 配置Groovy开发环境(Windows)

    1.配置java环境 跳过具体配置 C:\Users\Administrator>java -version java version "1.8.0_45" Java(TM) ...

  10. 学会阅读Java字节码

    1.Class文件基础   (1)文件格式     Class文件的结构不像XML等描述语言那样松散自由.由于它没有任何分隔符号, 所以,以上数据项无论是顺序还是数量都是被严格限定的.哪个字节代表什么 ...