mysql57开启biglog并查看biglog保姆级教程

目录

biglog简介

binlog使用详细步骤

1.修改mysql配置文件

2.重启mysql

3.操作数据库

4.查看binglog

4.1mysqlbinlog示例:

4.2mysqlbinlog将biglog写入文件示例:

4.2.1创建表生成的biglog示例:

4.2.2插入表生成的biglog示例

4.2.3更新表biglog示例


biglog简介

binlog 就是binary log,二进制日志文件,这个文件记录了MySQL所有的DML操作。通过binlog日志我们可以做数据恢复,增量备份,主主复制和主从复制等等。

binlog使用详细步骤

1.修改mysql配置文件

vi /etc/my.cnf

[mysqld]下增加如下配置


log-bin=mysql-bin
server-id=1

说明:log-bin指定了binlog的前缀名,server-id必须唯一且不同于其他MySQL服务器

2.重启mysql

centos重启示例

systemctl restart mysqld

3.操作数据库

往数据库中的某个表新增一条记录或者创建表都会往biglog文件中写入内容

4.查看binglog

cd /var/lib/mysql/mysql-bin
ll -la

可以看到会有类似mysql-bin.000001的文件生成

drwxr-x--x.  6 mysql mysql     4096 3月  13 22:44 .
drwxr-xr-x. 27 root  root      4096 8月  29 2023 ..
-rw-r-----.  1 mysql mysql       56 8月  29 2023 auto.cnf
-rw-------.  1 mysql mysql     1680 8月  29 2023 ca-key.pem
-rw-r--r--.  1 mysql mysql     1112 8月  29 2023 ca.pem
-rw-r--r--.  1 mysql mysql     1112 8月  29 2023 client-cert.pem
-rw-------.  1 mysql mysql     1680 8月  29 2023 client-key.pem
-rw-r-----.  1 mysql mysql      283 3月  13 22:40 ib_buffer_pool
-rw-r-----.  1 mysql mysql 12582912 3月  13 22:42 ibdata1
-rw-r-----.  1 mysql mysql 50331648 3月  13 22:42 ib_logfile0
-rw-r-----.  1 mysql mysql 50331648 8月  29 2023 ib_logfile1
-rw-r-----.  1 mysql mysql 12582912 3月  13 22:42 ibtmp1
drwxr-x---.  2 mysql mysql     4096 8月  29 2023 mysql
-rw-r-----.  1 mysql mysql      962 3月  13 22:42 mysql-bin.000001
-rw-r-----.  1 mysql mysql       19 3月  13 22:40 mysql-bin.index
srwxrwxrwx.  1 mysql mysql        0 3月  13 22:40 mysql.sock
-rw-------.  1 mysql mysql        5 3月  13 22:40 mysql.sock.lock
drwxr-x---.  2 mysql mysql     8192 8月  29 2023 performance_schema
-rw-------.  1 mysql mysql     1680 8月  29 2023 private_key.pem
-rw-r--r--.  1 mysql mysql      452 8月  29 2023 public_key.pem
-rw-r--r--.  1 mysql mysql     1112 8月  29 2023 server-cert.pem
-rw-------.  1 mysql mysql     1680 8月  29 2023 server-key.pem
drwxr-x---.  2 mysql mysql     8192 8月  29 2023 sys
drwxr-x---.  2 mysql mysql       58 3月  13 22:41 test

直接查看binlog可以看到有很多乱码

正确查看方式是使用命令查看

4.1mysqlbinlog示例:

mysqlbinlog -v /var/lib/mysql/mysql-bin.000001

也可以把内容写入到文件中

4.2mysqlbinlog将biglog写入文件示例:

 mysqlbinlog -v /var/lib/mysql/mysql-bin.000001 > /opt/mysql-bin-000001.txt

示例中将binlog写入了文件 /opt/mysql-bin-000001.txt中

此时,查看文件/opt/mysql-bin-000001.txt就没有乱码了,但是和执行sql还是有差异的

4.2.1创建表生成的biglog示例:
#240313 22:41:55 server id 1  end_log_pos 667 CRC32 0x5b0f29d8  Query   thread_id=3     exec_time=0     error_code=0
use `test`/*!*/;
SET TIMESTAMP=1710340915/*!*/;
CREATE TABLE `test`.`t_table`  (^M
  `id` int(0) NOT NULL,^M
  `name` varchar(255) NULL,^M
  `address` varchar(255) NULL,^M
  `create_time` datetime(0) NULL,^M
  `update_time` datetime(0) NULL,^M
  PRIMARY KEY (`id`)^M
)

说明,第一行是时间戳,240313表示2024年3月13日

22:41:55表示具体时间

下面是创建表语句

4.2.2插入表生成的biglog示例
#240313 22:42:19 server id 1  end_log_pos 931 CRC32 0x038eed84  Write_rows: table id 101 flags: STMT_END_F

BINLOG '
S7vxZRMBAAAAPAAAAGADAAAAAGUAAAAAAAEABHRlc3QAB3RfdGFibGUABQMPDxISBv8A/wAAAB7D
vV1G
S7vxZR4BAAAAQwAAAKMDAAAAAGUAAAAAAAEAAgAF/+ABAAAACHpoYW5nc2FuB2JlaWppbmeZsttq
jpmy22qRhO2OAw==
'/*!*/;
### INSERT INTO `test`.`t_table`
### SET
###   @1=1
###   @2='zhangsan'
###   @3='beijing'
###   @4='2024-03-13 22:42:14'
###   @5='2024-03-13 22:42:17'
# at 931
#240313 22:42:19 server id 1  end_log_pos 962 CRC32 0xb2c0a6e7  Xid = 62
COMMIT/*!*/;

4.2.3更新表biglog示例
#240313 23:04:34 server id 1  end_log_pos 1558 CRC32 0xfbe11994         Update_rows: table id 102 flags: STMT_END_F

BINLOG '
gsDxZRMBAAAAPAAAAKUFAAAAAGYAAAAAAAEABHRlc3QAB3RfdGFibGUABQMPDxISBv8A/wAAAB6l
yfEH
gsDxZR8BAAAAcQAAABYGAAAAAGYAAAAAAAEAAgAF///gAQAAAAh6aGFuZ3NhbgdiZWlqaW5nmbLb
ao6ZsttqkeABAAAADHpoYW5nc2FuLTg4OBBiZWlqaW5nLWNoYW95YW5nmbLbao6ZsttxIpQZ4fs=
'/*!*/;
### UPDATE `test`.`t_table`
### WHERE
###   @1=1
###   @2='zhangsan'
###   @3='beijing'
###   @4='2024-03-13 22:42:14'
###   @5='2024-03-13 22:42:17'
### SET
###   @1=1
###   @2='zhangsan-888'
###   @3='beijing-chaoyang'
###   @4='2024-03-13 22:42:14'
###   @5='2024-03-13 23:04:34'

 

特别说明:where与set之间都是原始值,set后面都是更新后的值

相关推荐

  1. mysql57开启biglog查看biglog保姆教程

    2024-03-17 20:30:03       37 阅读
  2. Mysql开启binlog

    2024-03-17 20:30:03       24 阅读
  3. mysql binlog

    2024-03-17 20:30:03       48 阅读
  4. 如何开启MySQLbinlog日志

    2024-03-17 20:30:03       35 阅读
  5. mysql参数配置binlog

    2024-03-17 20:30:03       48 阅读
  6. mysql binlog入门

    2024-03-17 20:30:03       29 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-17 20:30:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-17 20:30:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-17 20:30:03       82 阅读
  4. Python语言-面向对象

    2024-03-17 20:30:03       91 阅读

热门阅读

  1. 鸿蒙开发 -- ui结构样式复用

    2024-03-17 20:30:03       46 阅读
  2. koa2+vue3通过exceljs实现数据导出excel文档

    2024-03-17 20:30:03       39 阅读
  3. IOS面试题object-c 146-150

    2024-03-17 20:30:03       39 阅读
  4. 循序渐进理解数据库基本概念

    2024-03-17 20:30:03       40 阅读
  5. 分布式微服务 - 总概

    2024-03-17 20:30:03       48 阅读
  6. Golang 泛型定义类型的时候前面 ~ 代表什么意思

    2024-03-17 20:30:03       42 阅读
  7. 音视频实战---音视频频解码

    2024-03-17 20:30:03       43 阅读
  8. 我的创作纪念日

    2024-03-17 20:30:03       41 阅读
  9. 静态绑定和动态绑定的介绍?

    2024-03-17 20:30:03       40 阅读
  10. 树莓派 ubuntu 23.10 mantic 换阿里云源

    2024-03-17 20:30:03       41 阅读
  11. Microsoft VBA Excel 提取相同名称的整列数据

    2024-03-17 20:30:03       45 阅读
  12. ./experiment.sh: line 64: python3.6: command not found

    2024-03-17 20:30:03       39 阅读
  13. 435. 无重叠区间

    2024-03-17 20:30:03       42 阅读