第3章 文件

 

  MySQL会用到的文件

3.1 参数文件

  mysql启动的时候会读取的配置文件,也是之前装Mysql时候需要修改的配置文件,比如修改配置文件允许远程访问。MySQL的配置文件有多个,按照顺序读取,如果有重复的字段设置以最后一个为准。

  

  没有配置文件也是可以启动的,但是是按照编译时候默认的参数来启动的,既然是编译时候默认的那也就不能修改,所以还是得有一个参数文件。

3.1.1 什么是参数

  参数就是参数啊……启动的时候的配置,例如缓存池的大小,是否允许非localhost的请求访问数据。可以通过show variables结合like指令搜索查看某个想确定的参数。

3.1.2 参数类型

  参数类型分为动态和静态,动态类型的参数在运行期间可以修改,静态参数MySQL启动以后就不能修改。对动态参数的修改又分为两种,一种是session级别一种是global级别,即修改后的结果是只在当前会话生效还是全局都生效。

  首先看到当前全局的read_buffer_size的大小。

  

  然后修改了read_buffer_size的大小

  

  但是修改之后查看全局的read_buffer_size的大小并没有改变

  

  改变的是session级别的read_buffer_size

  

  如果想要对全局的动态变量进行修改需要制定@@global参数

 

3.2 日志文件

3.2.1 错误日志

  记录着mysql运行期间所有的错误记录,也包括警告等信息。在show variables里查看错误日志的位置。

3.2.2 慢查询日志

  用于sql语句的优化,在执行所有sql语句的时候如果某个sql语句的执行时间大于指定的阈值,就会写入慢查询日志里,通过分析慢查询日志可以找到需要优化的sql语句。

  我电脑上是14.14的版本,和书上的版本不一样,相关的变量的名称也不一样。所以我首先检索和slow相关的所有变量,可以看到下面两个个变量是和书上的变量相对应的,是否开启慢查询和慢查询日志的位置。

  long_query_time对应着慢查询的阈值。

  

  如果某些查询没有使用索引,那么即使他的查询时间没有超过阈值,但是他仍然有优化的空间,所以也希望把没有使用索引的sql语句放到查询日志里。log_queries_not_using_indexes对应着开启这一功能。

 

  

  随着MySQL运行时间的增长,慢查询日志的长度也会增加,人肉去看这个日志就会不现实,为此MySQL提供了两种优化方案。

  一种是使用mysqldumpslow命令,该命令提供了对慢查询日志的检索功能。

  一种是不直接查看慢查询的文本日志,而是查看慢查日志记录的对应的表里。该表存储在mysql.slow_log的位置。

  这个太乱了,我还是喜欢直观的。

  这个就很不错

 

  但是默认是不写在这个表里的,是写在文件里的。其实不只是慢查询的日志默认写在文件里,所有的日志都是默认写在文件里的,但是可以设置成输出到表里,虽然这样会增加一定的存储开销。通过使用上面提到的set命令,并把作用域设置成global使所有会话的所有日志都输出到表里。

  

  开启慢查询的目的是为了优化sql语句,其中之一的优化方式是分析逻辑读取和物理读取的比例。物理读取是从磁盘读,逻辑读取既包含磁盘也包含缓冲池。  

3.2.3 查询日志

  所有的sql操作都被记录在这个日志里,无论他是否被正确执行。

  首先要找到这个查询日志的文件的位置,书上没有写叫啥,我就暴力的搜索了含log的所有variables。

  

  原来它叫general_log,而且默认是关闭的,先打开。本着节省空间的目的,我决定只在session里打开。

  

  但是他不让,必须是global的

  

  现在在看这个gerenal_log已经打开了

  

  随便查询一个语句,然后vi看一哈。

  

  成了!

3.2.4 二进制日志

  记录了所有对数据库进行修改的记录,只包括update delete操作。

3.3 套接字文件

  本地连接MySQL可以使用套接字方式,此时需要一个套接字文件。

 

3.4 pid文件

  MySQL启动的时候会把自己的进程ID写到PID文件里

 

3.5 表结构文件

  每个表、视图都有一个以frm结尾的文件来存储该表或者试图的结构

 

3.6 InnoDB存储引擎文件

3.6.1 表空间文件

3.6.2 重做日志文件

  类似于之前的bin日志,每次更新前先写入redo log里,并修改内存里的内容,等到时机合适的时候再把内容更新到磁盘里,这是提高效率的一种方式,同时也是安全性的体现,有了redo log就可以恢复数据库。

  redo log是按照组来组织的,至少有一组redo log,一组里至少有两个redo log,每次写的时候先往redo log1里写,写满的时候再去redo log2里写,然后循环使用。当然MySQL会在合适的时候把redo log里的内容刷到磁盘里。

  和redo log相关的参数如下

  

  file_size代表日志文件大小。in_group代表有几个日志文件组。home_dir是路径。ahead_size代表向redo log里追加的大小。

    

  这里要注意区别之前的bin log,bin log是server层的日志,在InnoDB引擎被开发出来之前,MySQL只有bin log日志,bin log日志对于所有的引擎都是可以使用的。其次二者存储的内容不同,redo log 是物理日志,记录的是“在某个数据页上做了什么修改”;binlog 是逻辑日志,记录的是这个语句的原始逻辑,比如“给 ID=2 这一行的 c 字段加 1 ”。redo log 是循环写的,空间固定会用完;binlog 是可以追加写入的。“追加写”是指 binlog 文件写到一定大小后会切换到下一个,并不会覆盖以前的日志。

 

posted @ 2019-02-24 13:56  AshOfTime  阅读(119)  评论(0编辑  收藏  举报