MySQL学习笔记之日志管理(1/2)

一、日志类型:

MySQL有几个不同的日志文件,可以帮助你找出mysqld内部发生的事情:

日志文件  记入文件中的信息类型
错误日志  记录启动、运行或停止时出现的问题。
查询日志  记录建立的客户端连接和执行的语句。
二进制日志  记录所有更改数据的语句。主要用于复制和即时点恢复。
慢日志  记录所有执行时间超过long_query_time秒的所有查询或不使用索引的查询。
事务日志  记录InnoDB等支持事务的存储引擎执行事务时产生的日志。

默认情况下,所有日志创建于mysqld数据目录中。通过刷新日志,你可以强制 mysqld来关闭和重新打开日志文件(或者在某些情况下切换到一个新的日志)。当你执行一个FLUSH LOGS语句或执行mysqladmin flush-logs或mysqladmin refresh时,出现日志刷新。如果你正使用MySQL复制功能,从复制服务器将维护更多日志文件,被称为接替日志。
二、错误日志
错误日志主要记录如下几种日志:

    服务器启动和关闭过程中的信息
    服务器运行过程中的错误信息
    事件调度器运行一个时间是产生的信息
    在从服务器上启动从服务器进程是产生的信息

错误日志定义:

可以用--log-error[=file_name]选项来指定mysqld保存错误日志文件的位置。如果没有给定file_name值,mysqld使用错误日志名host_name.err 并在数据目录中写入日志文件。如果你执行FLUSH LOGS,错误日志用-old重新命名后缀并且mysqld创建一个新的空日志文件。(如果未给出--log-error选项,则不会重新命名)。

查看当前错误日志配置:

  

 代码如下 复制代码
  mysql> SHOW GLOBAL VARIABLES LIKE '%log_error%';
    +---------------+---------------------------------------+
    | Variable_name  | Value                                                  |
    +---------------+---------------------------------------+
    | log_error          | /data/mysql/localhost.localdomain.err |
    +---------------+---------------------------------------+
    1 row in set (0.45 sec)

是否记录警告日志:

   

 代码如下 复制代码
mysql> SHOW GLOBAL VARIABLES LIKE '%log_warnings%';
    +---------------+-------+
    | Variable_name | Value   |
    +---------------+-------+
    | log_warnings    | 1         |
    +---------------+-------+
    1 row in set (0.00 sec)

三、通用查询日志

    启动开关:general_log={ON|OFF}
    日志文件变量:general_log_file[=/PATH/TO/file]
    全局日志开关:log={ON|OFF}   该开关打开后,所有日志都会被启用
    记录类型:log_output={TABLE|FILE|NONE}

因此,要启用通用查询日志,需要至少配置general_log=ON,log_output={TABLE|FILE}。而general_log_file如果没有指定,默认名是host_name.log。

看看上述几个值的默认配置:

   

 代码如下 复制代码

mysql> SHOW GLOBAL VARIABLES LIKE '%general_log%';
    +------------------+---------------------------+
    | Variable_name      | Value                                |
    +------------------+---------------------------+
    | general_log           | OFF                                  |
    | general_log_file     | /data/mysql/localhost.log |
    +------------------+---------------------------+

    mysql> SHOW GLOBAL VARIABLES LIKE '%log_output%';
    +---------------+-------+
    | Variable_name  | Value  |
    +---------------+-------+
    | log_output       | FILE     |
    +---------------+-------+

四、慢查询日志:

MySQL如果启用了slow_query_log=ON选项,就会记录执行时间超过long_query_time的查询(初使表锁定的时间不算作执行时间)。日志记录文件为slow_query_log_file[=file_name],如果没有给出file_name值, 默认为主机名,后缀为-slow.log。如果给出了文件名,但不是绝对路径名,文件则写入数据目录。

默认与慢查询相关变量:

   

 代码如下 复制代码
mysql> SHOW GLOBAL VARIABLES LIKE '%slow_query_log%';
    +----------------------------+--------------------------------+
    | Variable_name                     | Value                                        |
    +----------------------------+--------------------------------+
    | slow_query_log                    | OFF                                          |
    | slow_query_log_file              | /data/mysql/localhost-slow.log |
    +----------------------------+--------------------------------+

服务器参数设定方法与通用查询日志相同,不做解释。

默认没有启用慢查询,为了服务器调优,建议开启。

 

 代码如下 复制代码
   mysql> SET GLOBAL slow_query_log=ON;
    Query OK, 0 rows affected (1.45 sec)

    ##如果要长久生效,则需要在配置文件中定义。

那么多久算是慢呢?

如果查询时长超过long_query_time的定义值(默认10秒),即为慢查询:

   

 代码如下 复制代码
mysql> SHOW GLOBAL VARIABLES LIKE 'long_query_time';
    +-----------------+-----------+
    | Variable_name    | Value         |
    +-----------------+-----------+
    | long_query_time | 10.000000 |
    +-----------------+-----------+

 
五、二进制日志:
二进制日志启动开关:log-bin [= file_name]

在5.6及以上版本一定要手动指定。5.6以下版本默认file_name为$datadir/mysqld-binlog

二进制日志用于记录所有更改数据的语句。主要用于复制和即时点恢复。

查看二进制日志的工具为:mysqlbinlog

二进制日志包含了所有更新了数据或者已经潜在更新了数据(例如,没有匹配任何行的一个DELETE)的所有语句。语句以“事件”的形式保存,它描述数据更改。二进制日志还包含关于每个更新数据库的语句的执行时间信息。它不包含没有修改任何数据的语句。

二进制日志的主要目的是在数据库存在故障时,恢复时能够最大可能地更新数据库(即时点恢复),因为二进制日志包含备份后进行的所有更新。二进制日志还用于在主复制服务器上记录所有将发送给从服务器的语句。
那么二进制日志是记录执行的语句还是执行后的结果数据呢?

第一种情况:

加入一个表有10万行数据,而现在要执行一个如下语句将amount字段的值全部在原来的基础上增加1000:

 代码如下 复制代码

    UPDATE sales.january SET amount=amount+1000;

此时如果要记录执行后的结果数据的话,日志会非常大。

因此在这种情况下应记录执行语句。这种方式就是基于语句的二进制日志。

第二种情况:

如果向某个字段插入的是当前的时间呢?如下:

 代码如下 复制代码

    INSERT INTO tb SET Birthdate=CURRENT_TIME();

此时就不能记录语句了,因为不同时间执行的结果是不一样的。这是应该记录这一行的值,这种就是基于行(row)的二进制日志。

在有些情况,可能会结合两种方式来记录,这种叫做混合方式的二进制日志。
二进制日志记录时间:

默认情况下,并不是每次写入时都将二进制日志与硬盘同步。因此如果操作系统或机器(不仅仅是MySQL服务器)崩溃,有可能二进制日志中最后的语句丢失了。要想防止这种情况,你可以使用sync_binlog全局变量(1是最安全的值,但也是最慢的),使二进制日志在每N次二进制日志写入后与硬盘同步。

对非事务表的更新执行完毕后立即保存到二进制日志中。对于事务表,例如BDB或InnoDB表,所有更改表的更新(UPDATE、DELETE或INSERT) 被缓存起来,直到服务器接收到COMMIT语句。在该点,执行完COMMIT之前,mysqld将整个事务写入二进制日志。当处理事务的线程启动时,它为缓冲查询分配binlog_cache_size大小的内存。如果语句大于该值,线程则打开临时文件来保存事务。线程结束后临时文件被删除。
二进制日志的管理:

    日志的滚动:

在my.cnf中设定max_binlog_size = 200M,表示限制二进制日志最大尺寸为200M,超过200M后进行滚动。MySQL的滚动方式与其他日志不太一样,滚动时会创建一个新的编号大1的日志用于记录最新的日志,而原日志名字不会被改变。

每次重启MySQL服务,日志都会自动滚动一次。

另外如果需要手动滚动,则使用命令:

 代码如下 复制代码

    mysql> FLUSH LOGS;

    日志的查看:

查看有哪些二进制日志文件:

   

 代码如下 复制代码

mysql> SHOW BINARY LOGS;

    +----------------------+-----------+
    | Log_name                   | File_size    |
    +----------------------+-----------+
    | mysqld-binlog.000001 |       143   |
    | mysqld-binlog.000002 |       120   |
    +----------------------+-----------+

查看当前正在使用的是哪一个二进制日志文件:

 代码如下 复制代码

    mysql> SHOW MASTER STATUS;
    +----------------------+----------+--------------+------------------+-------------------+
    | File                             | Position   | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------------+----------+--------------+------------------+-------------------+
    | mysqld-binlog.000002 |      120   |                       |                            |                              |
    +----------------------+----------+--------------+------------------+-------------------+

    ##做个操作后再次查看:

    mysql> use jiaowu;

    Database changed
    mysql> INSERT INTO students (Name,Age) VALUES ('stu1',24);
    Query OK, 1 row affected (0.07 sec)

    mysql> SHOW MASTER STATUS;
    +----------------------+----------+--------------+------------------+-------------------+
    | File                             | Position   | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------------+----------+--------------+------------------+-------------------+
    | mysqld-binlog.000002 |      394   |                      |                             |                              |
    +----------------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)

    ##可以看到Position(位置)已经改变。

查看二进制日志内容:

  

 代码如下 复制代码

  mysql> SHOW BINLOG EVENTS IN 'mysqld-binlog.000002';
    +----------------------+-----+-------------+-----------+-------------+------------------------------------------------------------------+
    | Log_name             | Pos | Event_type  | Server_id | End_log_pos | Info                                                             |
    +----------------------+-----+-------------+-----------+-------------+------------------------------------------------------------------+
    | mysqld-binlog.000002 |   4 | Format_desc |         1 |         120 | Server ver: 5.6.13-log, Binlog ver: 4                            |
    | mysqld-binlog.000002 | 120 | Query       |         1 |         203 | BEGIN                                                            |
    | mysqld-binlog.000002 | 203 | Intvar      |         1 |         235 | INSERT_ID=11                                                     |
    | mysqld-binlog.000002 | 235 | Query       |         1 |         363 | use `jiaowu`; INSERT INTO students (Name,Age) VALUES ('stu1',24) |
    | mysqld-binlog.000002 | 363 | Xid         |         1 |         394 | COMMIT /* xid=13 */                                              |
    +----------------------+-----+-------------+-----------+-------------+------------------------------------------------------------------+
    5 rows in set (0.01 sec)

    ##该语句还可以加上Position(位置),指定显示从哪个Position(位置)开始:

    mysql> SHOW BINLOG EVENTS IN 'mysqld-binlog.000002' FROM 203;
    +----------------------+-----+------------+-----------+-------------+------------------------------------------------------------------+
    | Log_name             | Pos | Event_type | Server_id | End_log_pos | Info                                                             |
    +----------------------+-----+------------+-----------+-------------+------------------------------------------------------------------+
    | mysqld-binlog.000002 | 203 | Intvar     |         1 |         235 | INSERT_ID=11                                                     |
    | mysqld-binlog.000002 | 235 | Query      |         1 |         363 | use `jiaowu`; INSERT INTO students (Name,Age) VALUES ('stu1',24) |
    | mysqld-binlog.000002 | 363 | Xid        |         1 |         394 | COMMIT /* xid=13 */                                              |
    +----------------------+-----+------------+-----------+-------------+------------------------------------------------------------------+
    3 rows in set (0.00 sec)

首页 1 2 末页

时间: 2024-09-21 22:44:20

MySQL学习笔记之日志管理(1/2)的相关文章

MySQL学习笔记之数据的增、删、改实现方法_Mysql

本文实例讲述了MySQL学习笔记之数据的增.删.改实现方法.分享给大家供大家参考,具体如下: 一.增加数据 插入代码格式: insert into 表明 [列名-] values (值-) create table test21(name varchar(32)); insert into test21 (name) values ('huangbiao'); 插入原则: 1.插入的数据应与字段的数据类型相同 2.数据的大小应该在列的规定范围内 3.在values中列出的数据位置必须与被加入的列

MySQL学习笔记之数据定义表约束,分页方法总结_Mysql

本文实例讲述了MySQL学习笔记之数据定义表约束,分页方法.分享给大家供大家参考,具体如下: 1. primary key 主键 特点:主键是用于唯一标识一条记录的约束,一张表最多只能有一个主键,不能为空也不能重复 create table user1(id int primary key,name varchar(32)); mysql> insert into user1 values(1,'hb'); Query OK, 1 row affected (0.10 sec) mysql>

MySQL学习笔记之创建、删除、修改表的方法_Mysql

本文实例讲述了MySQL学习笔记之创建.删除.修改表的方法.分享给大家供大家参考,具体如下: 创建表: create table users( id int, name varchar(64), sex bit(1), birthday date, Entry_date date, job varchar(32), salary float, resume text ); 1 添加列: alter table 表名 add 列名 数据类型 alter table users add image

Mysql学习笔记(六)增删改查

原文:Mysql学习笔记(六)增删改查 PS:数据库最基本的操作就是增删改查了... 学习内容: 数据库的增删改查 1.增...其实就是向数据库中插入数据.. 插入语句 insert into table_name values("要插入的数据"); 比如说,我们先创建一个宠物表,用来记录宠物的基本信息以及所有者... create table pet ( name varchar(20), owner varchar(20), species varchar(20), sex cha

Mysql学习笔记(十一)临时表+视图

原文:Mysql学习笔记(十一)临时表+视图 学习内容: 临时表和视图的基本操作... 临时表与视图的使用范围... 1.临时表   临时表:临时表,想必大家都知道这个概念的存在...但是我们什么时候应该使用到临时表呢?当一个数据库存在着大量的数据的时候,我们想要获取到这个数据集合的一个子集,那么我们就可以使用临时表来保存我们想要的数据..然后对临时表进行操作就可以了...使用临时表必然是有原因的..使用临时表会加快数据库的查询性能.... create temporary table tmp_

Mysql学习笔记(一)数据类型

原文:Mysql学习笔记(一)数据类型 学习内容: Mysql基本数据类型. 1.数字类型.. i.整型     Mysql数据类型             含义(有符号)     tinyint(m) 一个字节 范围(-128~127)     smallint(m) 两个字节 范围(-32768~32767)     mediumint(m) 三个字节 范围(-8388608~8388607)     int(m) 四个字节 范围(-2147483648~2147483647)     bi

Mysql学习笔记(十)存储过程与函数 + 知识点补充(having与where的区别)

原文:Mysql学习笔记(十)存储过程与函数 + 知识点补充(having与where的区别) 学习内容:存储程序与函数...这一章学的我是云里雾里的... 1.存储过程...   Mysql存储过程是从mysql 5.0开始增加的一个新功能.存储过程的优点其实有很多,不过我觉得存储过程最重要的优点就是实现了SQL代码的封装,那么我们为什么需要封装SQL语句呢?原因就是当我们在面对一个庞大的数据库的时候,当我们使用外部程序去访问数据库的时候...我们总不能在外部程序中内嵌很多的SQL语句吧...

Mysql学习笔记(三)运算符和控制流函数

原文:Mysql学习笔记(三)运算符和控制流函数 本章学习内容: 1.操作符 2.控制流程函数   操作符: i.圆括号.. 简单的介绍一下圆括号,圆括号的使用的目的是规定计算表达式的顺序...这个想必大家都熟悉例如  mysql>select 1+(2*3) mysql>select (1+2)*3 ii.比较运算符. 比较运算符就比较多了,并且也很常用..比如   = 等于: mysql> SELECT 1 = 0; -> 0 mysql> SELECT '0' = 0;

Mysql学习笔记(二)数据类型 补充

原文:Mysql学习笔记(二)数据类型 补充 PS:简单的补充一下数据类型里的String类型以及列类型... 学习内容: 1.String类型 2.列类型存储需求   String类型: i.char与varchar char与varchar的类型相似,但是他们的保存方式和检索方式不同... char的存储结构是固定长度的存储...即指定了几个字节,那么就占用几个字节,如char(4),那么无论存入的是什么字串,那么都占用四个字节...char的 可表示长度范围为0-255的任何值,当保存的字