MySQL日志管理

2018-06-18 01:04:04来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

MySQL日志管理

查询有关日志的变量:show global variables like '%log%' ;
      特别提醒: 如果不明白mysql中的变量请点击 找到其中的  ”mysql服务器变量“ 部分

所有变量全部可以配置在配置文件中

A. 错误日志:
     记录内容: 服务器启动和关闭过程中的信息
           服务器运行过程中的错误信息
         事件调度器运行一个事件时产生的信息
           在从服务器上启动从服务器进程时产生的信息

1. log_error=文件路径/文件名 : 定义错误日志文件,作用范围为全局或会话级别 ,可用于配置文件,属于非动态变量

2. log_warnings= :设定是否将警告信息记录进错误日志,1为启用(默认),0为禁用,而其值为大于1的数值时表示将新发起连接时产生的"失败连接"和"拒绝访问"也记录进错误日志


B. 一般查询日志:
    记录内容: 每执行一个select 语句,都把相关信息记录下来 ,当 log=yes 时(5.6已经弃用) 执行dml语句都会记录到一般查询日志中

1.  general_log={ON|OFF} : 设定是否启用查询日志,默认值为取决于在启动mysqld时是否使用了–general_log选项。如若启用此项,其输出位置则由log_output选项进行定义,如果log_output的值设定为NONE,即使用启用查询日志,其也不会记录任何日志信息。作用范围为全局,可用于配置文件,属动态变量。

2.  general_log_file=文件路径/文件名 : 定义查询日志文件,默认为“hostname.log” 作用范围为全局 可用于配置文件,属于动态变量

3.  log={YES|NO} : 是否启用记录所有语句的日志信息于一般查询日志中,默认为OFF,5.6已经弃用

4.  log_output={TABLE|FILE|NONE} : 定义一般查询日志和慢查询日志的保存方式,可以是TABLE,FILE,NONE也可以是TABLE及FILE的组合(用逗号隔开),默认为TABLE,如果出现了NONE,那么其他设定都将失效,同时无论是否启用日志功能,也不会记录任何相关信息。作用范围为全局 可用于配置文件,属于动态变量

5.  sql_log_off={ON|OFF} : 用于控制是否禁止将一般查询日志类信息记录进查询日志文件。默认为OFF,表示不禁止记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。

 C.  慢查询日志:(慢查询是指查询的执行时长超过long_query_time参数所设定时长的事件)

1.  long_query_time= : 查询时长超过long_query_time指定的时长的就为慢查询, 这里的语句执行的时长为实际的执行时间,而非在cpu上的执行时间,默认为10秒钟,因此,负载较重的服务器上更容易产生慢查询。其最小值为0,默认值为10,单位是秒钟。它也支持毫秒级的解析度。作用范围为全局或会话级别,可用于配置文件,属动态变量。

2.  log_slow_queries={YES|NO} :是否记录慢查询日志,。 5.6将其该为了 slow_query_log ,作用范围为全局级别,可用于配置文件,属动态变量

3.  slow_query_log={ON|OFF} : 设定是否启用慢查询日志,0或OFF表示禁用,1或ON 表示启用,日志的输出位置取决于log_output变量的定义,如果其值为NONE即使slow_query_log为ON,也不会记录任何慢查询信息, 作用范围为全局 可用于配置文件,属于动态变量


4.  slow_query_log_file=文件路径/位置 : 设定慢查询日志文件的名称。默认为hostname-slow.log,但可以通过–slow_query_log_file选项修改。作用范围为全局级别,可用于选项文件,属动态变量。

5.  log_queries_not_using_indexes  ={ON|OFF} : 设定是否将没有使用索引的查询操作记录到慢查询日志。作用范围为全局级别,可用于配置文件,属动态变量。

 

D.  二进制日志:
      记录内容: 任何引起或可能引起数据库变化的操作;

      用于复制、即时点恢复;
      只要重启mysql,二进制日志都会滚动

 

二进制日志的储存顺序
  首先保存到缓存中(内存中)—————>最后同步到二进制文件中

二进制日志事件格式(在文件中是怎么储存某个事件的):
      事件产生的时间 starttime
      事件相对位置(事件的开始位置是上个事件的结束位置) position

二进制日志文件有两类:
        索引文件 : 记录着能被服务器找的二进制文件
        二进制日志文件

查看当前正在使用的二进制日志文件: SHOW MASTER STATUS;
查看二进制日志文件: SHOW BINARY LOGS;
查看事件:SHOW BINLOG EVENTS IN '二进制日志文件名' [FROM 指定开始位置(position)];
删除指定二进制文件之前的日志文件 : PURGE BINARY LOGS TO '二进制日志文件'
滚动二进制日志或中继日志:FLUSH LOGS;
查看mysql二进制文件 :  mysqlbinlog  二进制文件 [ [----start-datetime] [-stop-datetime] ]  [ [--start-position ] [ --stop-position] ]
             --start-datetime  '年-月-日  时:分:秒'   : 指定开始时间 ,时间格式是 
             --stop-datetime : 指定结束时间
             --start-position : 指定开始位置
             --stop-position : 指定结束位置

 

1.  binlog_format={ROW|STATEMENT|MIXED} :   指定二进制日志的类型,默认为STATEMENT。如果设定了二进制日志的格式,却没有启用二进制日志,则MySQL启动时会产生警告日志信息并记录于错误日志中。作用范围为全局或会话,可用于配置文件,且属于动态变量。

        二进制日志的格式:
          基于语句: statement
          基于行: row
          混合方式: mixed

2.  expire_logs_days={0..99} : 设定二进制日志的过期天数,超出此天数的二进制日志文件将被自动删除。默认为0,表示不启用过期自动删除功能。如果启用此功能,自动删除工作通常发生在MySQL启动时或FLUSH日志时。作用范围为全局,可用于配置文件,属动态变量。

3. log_bin={YES|NO} : 是否启用二进制日志,设置二进制文件的位置(在配置文件中  log_bin=二进制文件的位置 ) ,如果为mysqld设定了–log-bin选项,则其值为ON,否则则为OFF。其仅用于显示是否启用了二进制日志,并不反应在配置文件中log-bin的设定值。作用范围为全局级别,属非动态变量。

 4. sql_log_bin={ON|OFF} : 用于控制二进制日志信息是否记录进二进制日志文件。默认为ON,表示启用记录功能。用户可以在会话级别修改此变量的值,但其必须具有SUPER权限。作用范围为全局和会话级别,属动态变量。

5.  log_slave_updates : 用于设定复制场景中的从服务器是否将从主服务器收到的更新操作记录进本机的二进制日志中。本参数设定的生效需要在从服务器上启用二进制日志功能。

6. max_binlog_cache_size{4096 .. 18446744073709547520} : 二进定日志缓存空间大小,5.5.9及以后的版本仅应用于事务缓存,其上限由max_binlog_stmt_cache_size决定。作用范围为全局级别,可用于配置文件,属动态变量。

7. sync_binlog=#  设定多久同步一次二进制日志至磁盘文件中(从内存中同步到二进制文件中),0表示不同步,任何正数值都表示对二进制每多少次写操作之后同步一次。当autocommit(事务自动提交)的值为1时,每条语句的执行都会引起二进制日志同步,否则,每个事务的提交会引起二进制日志同步。

8. autocommit={0|1}
 设定MySQL事务是否自动提交,1表示立即提交,0表示需要显式提交。作用范围为全局或会话,可用于配置文件中(但在5.5.8之前的版本中不可用于配置文件),属于动态变量。

9. max_binlog_size={4096 .. 1073741824} : 设定二进制日志文件上限,单位为字节,最小值为4K,最大值为1G,默认为1G。某事务所产生的日志信息只能写入一个二进制日志文件,因此,实际上的二进制日志文件可能大于这个指定的上限。作用范围为全局级别,可用于配置文件,属动态变量。


D.  中继日志
从主服务器的二进制日志文件中复制而来的事件,并保存为日志文件;

 

 

E.  事务日志:

    记录 :事务执行过程当中对数据的修改信息
  
  作用 :只有事务性存储引擎 用于保证原子性、一致性、隔离性和持久性(ACID);

事务日志保存的顺序:
  首先保存缓存(内存中)------->然后同步到事务日志文件中------->最后同步到数据文件中

mysql奔溃重启后必须保证( 崩溃恢复)
    已经提交的事务,相关的数据必须从日志文件中同步的数据文件中,
    没提交的事务,必须撤销

ACID,将随机IO转换为顺序IO;

 

1.  innodb_flush_log_at_trx_commit={0|1|2}   :定义然后将缓存中的事务日志同步到事务日志文件中  0表示每秒同步,并执行磁盘flush操作; 1(默认)表示每当有事务提交同步,并执行磁盘flush操作; 2: 每当有事务提交,但不执行磁盘flush操作; 

 2.  innodb_log_buffer_size={262144 .. 4294967295} : 设定InnoDB用于辅助完成日志文件写操作的日志缓冲区(事务日志的缓存区)大小,单位是字节,默认为8MB。较大的事务可以借助于更大的日志缓冲区来避免在事务完成之前将日志缓冲区的数据写入日志文件,以减少I/O操作进而提升系统性能。因此,在有着较大事务的应用场景中,建议为此变量设定一个更大的值。作用范围为全局级别,可用于选项文件,属非动态变量。

3.  innodb_log_file_size={108576 .. 4294967295} : 设定日志组(事务日志组)中每个日志文件的大小,单位是字节,默认值是5MB。较为明智的取值范围是从1MB到缓存池体积的1/n,其中n表示日志组中日志文件的个数。日志文件越大,在缓存池中需要执行的检查点刷写操作就越少,这意味着所需的I/O操作也就越少,然而这也会导致较慢的故障恢复速度。作用范围为全局级别,可用于选项文件,属非动态变量。

4.  innodb_log_files_in_group={2 .. 100} : 设定日志组(事务日志组)中日志文件的个数。InnoDB以循环的方式使用这些日志文件。默认值为2。作用范围为全局级别,可用于选项文件,属非动态变量

5.  innodb_log_group_home_dir=/PATH/TO/DIR :  设定InnoDB重做日志文件的存储目录。在缺省使用InnoDB日志相关的所有变量时,其默认会在数据目录中创建两个大小为5MB的名为ib_logfile0和ib_logfile1的日志文件。作用范围为全局级别,可用于选项文件,属非动态变量。

6.innodb_support_xa={TRUE|FLASE}:  用来定义innodb是否支持分布式事务。储存引擎事务在储存引擎内部被赋予了ACID属性,分布式(xa)事务是一种高层的事务,它利用”准备“和”提交“(prepare-then-commit)两段式的方式将ACID属性扩展到储存引擎外部,甚至是数据库外部,然而,”准备“阶段会导致额外的磁盘刷写操作。XA需要事务协调员,它会通知所有参与者准备提交事务(阶段1),当协调员从所有参与者哪里收到”就绪“信息时,它会指示所有参与者进行真正的”提交“操作,
此变量正是用于定义Innodb是否支持两段式提交的分布式事务,默认为启用,事实上,所有启用了二进制日志的并支持多个线程同时向二进制日志写入数据的mysql服务器都需要启用分布式事务,否则,多个线程对二进制日志的写入操作可能会以与原始次序不同的方式完成,这将会在基于二进制日志的恢复操作中或者是从服务器上创建出不同原始数据的结果。因此,除了仅有一个线程可以改变数据以外的其它应用场景都不应该禁用此功能。而在仅有一个线程可以修改数据的应用中,禁用此功能是安全的并可以提升Innodb表性能。作用范围是全局和会话级别

 

 

max_relay_log_size={4096..1073741824} 

设定从服务器上中继日志的体积上限,到达此限度时其会自动进行中继日志滚动。此参数值为0时,mysqld将使用max_binlog_size参数同时为二进制日志和中继日志设定日志文件体积上限。作用范围为全局级别,可用于配置文件,属动态变量。

  log_bin_trust_function_creators={TRUE|FALSE} : 此参数仅在启用二进制日志时有效,用于控制创建存储函数时如果会导致不安全的事件记录二进制日志条件下是否禁止创建存储函数。默认值为0,表示除非用户除了CREATE ROUTING或ALTER ROUTINE权限外还有SUPER权限,否则将禁止创建或修改存储函数,同时,还要求在创建函数时必需为之使用DETERMINISTIC属性,再不然就是附带READS SQL DATA或NO SQL属性。设置其值为1时则不启用这些限制。作用范围为全局级别,可用于配置文件,属动态变量。

relay_log=file_name 
设定中继日志的文件名称,默认为host_name-relay-bin。也可以使用绝对路径,以指定非数据目录来存储中继日志。作用范围为全局级别,可用于选项文件,属非动态变量。

relay_log_index=file_name 
设定中继日志的索引文件名,默认为为数据目录中的host_name-relay-bin.index。作用范围为全局级别,可用于选项文件,属非动态变量。

relay-log-info-file=file_name 
设定中继服务用于记录中继信息的文件,默认为数据目录中的relay-log.info。作用范围为全局级别,可用于选项文件,属非动态变量。

relay_log_purge={ON|OFF} 
设定对不再需要的中继日志是否自动进行清理。默认值为ON。作用范围为全局级别,可用于选项文件,属动态变量。

relay_log_space_limit=# 
设定用于存储所有中继日志文件的可用空间大小。默认为0,表示不限定。最大值取决于系统平台位数。作用范围为全局级别,可用于选项文件,属非动态变量。

 

 

 

 

 

MyISAM: 
不支持事务 
表锁 
不支持外键 
B树索引、FULLTEXT索引、空间索引 
支持表压缩 
.frm 
.MYD 
.MYI 
InnoDB: 
事务 
行级锁 
B树索引、聚簇索引、自适应hash索引 
表空间,raw磁盘设备; 
.frm 
.ibd

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:MySQL学习笔记

下一篇:MySQL数据库索引简介