日志是数据库的重要组成部分,主要用来记录数据库的运行情况、日常操作和错误信息。
mysql通用查询日志(general query log)
通用查询日志(general query log)用来记录用户的所有操作,包括启动和关闭 mysql 服务、更新语句和查询语句等。
默认情况下,通用查询日志功能是关闭的。可以通过以下命令查看通用查询日志是否开启,命令如下:
mysql> show variables like '%general%'; ------------------ ---------------------------------------------------------------- | variable_name | value | ------------------ ---------------------------------------------------------------- | general_log | off | | general_log_file | c:\programdata\mysql\mysql server 5.7\data\laptop-uhq6v8kp.log | ------------------ ---------------------------------------------------------------- 2 rows in set, 1 warning (0.01 sec)
从结果可以看出,通用查询日志是关闭的,general_log_file 变量指定了通用查询日志文件所在的位置。
启动和设置通用查询日志
在 mysql 中,可以通过在 mysql 配置文件添加 log 选项来开启通用查询日志,格式如下:
[mysqld] log=dir/filename
其中,dir 参数指定通用查询日志的存储路径;filename 参数指定日志的文件名。如果不指定存储路径,通用查询日志将默认存储到 mysql 数据库的数据文件夹下。如果不指定文件名,默认文件名为 hostname.log,其中 hostname 表示名。
查看通用查询日志
如果希望了解用户最近的操作,可以查看通用查询日志。通用查询日志以文本文件的形式存储,可以使用普通文本文件查看该类型日志内容。
例 1
首先我们查看通用查询日志功能是否是开启状态,然后查询 tb_student 表的记录,sql 命令和执行过程如下:
mysql> show variables like '%general%'; ------------------ ---------------------------------------------------------------- | variable_name | value | ------------------ ---------------------------------------------------------------- | general_log | on | | general_log_file | c:\programdata\mysql\mysql server 5.7\data\laptop-uhq6v8kp.log | ------------------ ---------------------------------------------------------------- 2 rows in set, 1 warning (0.02 sec) mysql> use test; database changed mysql> select * from tb_student; ---- -------- | id | name | ---- -------- | 1 | java | | 2 | mysql | | 3 | python | ---- --------
3 rows in set (0.06 sec)
执行成功后,打开通用查询日志,这里日志名称为 laptop-uhq6v8kp.log,下面是通用查询日志中的部分内容。
c:\program files\mysql\mysql server 5.7\bin\mysqld.exe, version: 5.7.29-log (mysql community server (gpl)). started with: tcp port: 3306, named pipe: mysql time id command argument 2020-05-29t06:43:44.382878z 7 quit 2020-05-29t06:44:10.001382z 8 connect root@localhost on using ssl/tls 2020-05-29t06:44:10.007532z 8 query select @@version_comment limit 1 2020-05-29t06:44:11.748179z 8 query show variables like '%general%' 2020-05-29t06:44:25.487472z 8 query select database() 2020-05-29t06:44:25.487748z 8 init db test 2020-05-29t06:44:35.390523z 8 query select * from tb_student
可以看出,该日志非常清晰地记录了客户端的所有行为。
mysql二进制日志(binary log)
二进制日志(binary log)也可叫作变更日志(update log),是 mysql 中非常重要的日志。主要用于记录数据库的变化情况,即 sql 语句的 ddl 和 dml 语句,不包含数据记录查询操作。
如果 mysql 数据库意外停止,可以通过二进制日志文件来查看用户执行了哪些操作,对数据库文件做了哪些修改,然后根据二进制日志文件中的记录来恢复数据库服务器。
默认情况下,二进制日志功能是关闭的。可以通过以下命令查看二进制日志是否开启,命令如下:
mysql> show variables like 'log_bin'; --------------- ------- | variable_name | value | --------------- ------- | log_bin | off | --------------- ------- 1 row in set, 1 warning (0.02 sec)
从结果可以看出,二进制日志是关闭的。
启动和设置二进制日志
在 mysql 中,可以通过在配置文件中添加 log-bin 选项来开启二进制日志,格式如下:
[mysqld] log-bin=dir/[filename]
其中,dir 参数指定二进制文件的存储路径;filename 参数指定二进制文件的文件名,其形式为 filename.number,number 的形式为 000001、000002 等。
每次重启 mysql 服务后,都会生成一个新的二进制日志文件,这些日志文件的文件名中 filename 部分不会改变,number 会不断递增。
如果没有 dir 和 filename 参数,二进制日志将默认存储在数据库的数据目录下,默认的文件名为 hostname-bin.number,其中 hostname 表示主机名。
下面在 my.ini 文件的 [mysqld] 组中添加以下语句:
log-bin
重启 mysql 服务器后,可以在 mysql 数据库的数据目录下看到 laptop-uhq6v8kp-bin.000001 这个文件,同时还生成了 laptop-uhq6v8kp-bin.index 文件。此处,mysql 服务器的主机名为 laptop-uhq6v8kp。
还可以在 my.ini 文件的 [mysqld] 组中进行如下修改。语句如下:
log-bin=c:log\mylog
重启 mysql 服务后,可以在 c:log 文件夹下看到 mylog.000001 文件和 mylog.index 文件。
查看二进制日志
1. 查看二进制日志文件列表
可以使用如下命令查看 mysql 中有哪些二进制日志文件:
mysql> show binary logs; ---------------------------- ----------- | log_name | file_size | ---------------------------- ----------- | laptop-uhq6v8kp-bin.000001 | 177 | | laptop-uhq6v8kp-bin.000002 | 154 | ---------------------------- ----------- 2 rows in set (0.00 sec)
2. 查看当前正在写入的二进制日志文件
可以使用以下命令查看当前 mysql 中正在写入的二进制日志文件。
mysql> show master status; ---------------------------- ---------- -------------- ------------------ ------------------- | file | position | binlog_do_db | binlog_ignore_db | executed_gtid_set | ---------------------------- ---------- -------------- ------------------ ------------------- | laptop-uhq6v8kp-bin.000002 | 154 | | | | ---------------------------- ---------- -------------- ------------------ ------------------- 1 row in set (0.00 sec)
3. 查看二进制日志文件内容
二进制日志使用二进制格式存储,不能直接打开查看。如果需要查看二进制日志,必须使用 mysqlbinlog 命令。
mysqlbinlog 命令的语法形式如下:
mysqlbinlog filename.number
mysqlbinlog 命令只在当前文件夹下查找指定的二进制日志,因此需要在二进制日志所在的目录下运行该命令,否则将会找不到指定的二进制日志文件。
例 1
下面使用 mysqlbinlog 命令,来查看 c:\log 目录下的 mylog.000001 文件,代码执行如下:
c:\users\11645>cd c:\log c:\log>mysqlbinlog mylog.000001 /*!50530 set @@session.pseudo_slave_mode=1*/; /*!50003 set @old_completion_type=@@completion_type,completion_type=0*/; delimiter /*!*/; # at 4 #200527 9:33:37 server id 1 end_log_pos 123 crc32 0x69738cfd start: binlog v 4, server v 5.7.29-log created 200527 9:33:37 at startup ......
由于日志内容较长,这里只展示了 mylog 中的部分内容。
使用 mysqlbinlog 命令时,可以指定二进制文件的存储路径。这样可以确保 mysqlbinlog 命令可以找到二进制文件。上面例子中的命令可以变为如下形式:
mysqlbinlog c:\log\mylog.000001
这样,mysqlbinlog 命令就会到 c:\log 目录下去查找 mylog.000001 文件。如果不指定路径,mysqlbinlog 命令将在当前目录下查找 mylog.000001 文件。
除了 filename.number 文件,mysql 还会生成一个名为 filename.index 的文件,这个文件存储着所有二进制日志文件的列表,可以用记事本打开该文件。
小技巧:实际工作中,二进制日志文件与数据库的数据文件不放在同一块硬盘上,这样即使数据文件所在的硬盘被破坏,也可以使用另一块硬盘上的二进制日志来恢复数据库文件。两块硬盘同时坏了的可能性要小得多,这样可以保证数据库中数据的安全。