MySQL 5.7开启并查看biglog的详细教程

 更新时间:2024年03月14日 09:23:51   作者:老王聊技术  
binlog 就是binary log,二进制日志文件,这个文件记录了MySQL所有的DML操作,通过binlog日志我们可以做数据恢复,增量备份,主主复制和主从复制等等,本文给大家介绍了MySQL 5.7开启并查看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后面都是更新后的值

到此这篇关于MySQL 5.7开启并查看biglog的详细教程的文章就介绍到这了,更多相关MySQL 5.7开启并查看biglog内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • mysql in索引慢查询优化实现步骤解析

    mysql in索引慢查询优化实现步骤解析

    这篇文章主要为大家介绍了mysql in慢查询优化实现步骤的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • MySQL 使用事件(Events)完成计划任务

    MySQL 使用事件(Events)完成计划任务

    事件(Events) 是在 MySQL 5.1后引入的,有点类似操作系统的计划任务(cron),但是周期性任务是内置在 MySQL 服务端执行的。本文讲述MySQL如何用事件完成计划任务
    2021-05-05
  • 最全的mysql查询语句整理

    最全的mysql查询语句整理

    这篇文章主要介绍了最全的mysql查询语句整理,需要的朋友可以参考下
    2016-06-06
  • Mysql索引结合explain分析示例

    Mysql索引结合explain分析示例

    本文主要介绍了Mysql索引结合explain分析示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • JDBC-idea导入mysql连接java的jar包(mac)的方法

    JDBC-idea导入mysql连接java的jar包(mac)的方法

    这篇文章主要介绍了JDBC-idea导入mysql连接java的jar包(mac)的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • Windows下mysql修改root密码的4种方法

    Windows下mysql修改root密码的4种方法

    这篇文章主要为大家详细介绍了windows下mysql修改root密码的4种方法,大家可以根据的自己的实际情况进行选择,感兴趣的小伙伴们可以参考一下
    2016-05-05
  • MySQL  Lock wait timeout exceeded错误解决

    MySQL  Lock wait timeout exceeded错误

    “Lock wait timeout exceeded” 是一个常见的MySQL错误,指示了潜在的性能问题或死锁,本文就来介绍一下如何解决,感兴趣的可以了解一下
    2024-05-05
  • SQL语句中EXISTS的详细用法大全

    SQL语句中EXISTS的详细用法大全

    最近重新用到了exists关键字,对于其基本用法记录一下,下面这篇文章主要给大家介绍了关于SQL语句中EXISTS的详细用法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06
  • asp+mysql+utf8 网页出现乱码问题的解决方法

    asp+mysql+utf8 网页出现乱码问题的解决方法

    无论在网页中加多少UTF8的定义,显示的结果都还是会有一些小格子,反而定义为gb2312,显示完全正常
    2014-03-03
  • MySQL下的RAND()优化案例分析

    MySQL下的RAND()优化案例分析

    这篇文章主要介绍了MySQL下的RAND()优化案例,包括对JOIN查询和子查询的优化,需要的朋友可以参考下
    2015-05-05

最新评论