mysql对数据的更新操作记录在哪个日志中?-kb88凯时官网登录

时间:2020-11-02
阅读:
免费资源网 - https://freexyz.cn/

日志是数据库的重要组成部分,主要用来记录数据库的运行情况、日常操作和错误信息。

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 的文件,这个文件存储着所有二进制日志文件的列表,可以用记事本打开该文件。

小技巧:实际工作中,二进制日志文件与数据库的数据文件不放在同一块硬盘上,这样即使数据文件所在的硬盘被破坏,也可以使用另一块硬盘上的二进制日志来恢复数据库文件。两块硬盘同时坏了的可能性要小得多,这样可以保证数据库中数据的安全。

免费资源网 - https://freexyz.cn/
返回顶部
顶部
网站地图