广告
返回顶部
首页 > 资讯 > 数据库 >MySQL中binlog日志的使用方法
  • 514
分享到

MySQL中binlog日志的使用方法

2023-06-14 06:06:16 514人浏览 泡泡鱼
摘要

这篇文章主要介绍MySQL中binlog日志的使用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!binlog 就是binary log,二进制日志文件,这个文件记录了Mysql所有的DML操作。通过binlog日

这篇文章主要介绍MySQL中binlog日志的使用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

binlog 就是binary log,二进制日志文件,这个文件记录了Mysql所有的DML操作。通过binlog日志我们可以做数据恢复,增量备份,主主复制和主从复制等等。对于开发者可能对binlog并不怎么关注,但是对于运维或者架构人员来讲是非常重要的。

mysql 5.7这个版本默认是不开启binlog日志的,具体的开启方式可以查看https://www.yisu.com/article/207953.htm

binlog开启成功之后,binlog文件的位置可以在my.inf配置文件中查看。也可以在Mysql的命令行中查看。命令行查看代码如下

show variables like '%log_bin%';

我们也可以看一下当前MySQL的binlog的情况

show master status;

MySQL中binlog日志的使用方法

从上图可以看到,当前只有一个binlog文件,文件名为:mysql-bin.000001。每当我们重启一次,会自动生成一个binlog文件,我们重启完毕之后再来执行同样的命令,内容如下:

MySQL中binlog日志的使用方法

存放binlog的目录下也多个了这么一个文件。

当然,我们也可以手动的来刷新binlog文件,通过 flush logs,同样会新创建一个binlog文件。实际上当服务器在重启时,也会调用flush logs操作。

MySQL中binlog日志的使用方法

如果我们想把这些文件全部清空,可以使用reset master 来处理

MySQL中binlog日志的使用方法

下面我来看针对单个文件的操作,首先我们想看一下文件的内容

找到binlog的目录,比如我们要看mysql-bin.000001

vi mysql-bin.000001

MySQL中binlog日志的使用方法

我们看到的一堆乱码。我们知道这是一堆的二进制文件,所以以文本的方式打开二进制文件一定是有问题的,那么我们该如何查看这个文件的内容呢?

mysql给我们提供了一个用于查看binlog日志的工具,叫做mysqlbinlog

mysqlbinlog myql-bin.000001

MySQL中binlog日志的使用方法

这个文件比较长,一次打开看不完怎么办呢,这里可以使用linux的管道,这里就不详细的说了,可以自己去查找关于linux的一些知识。

注意到上面的截图中有一个position字段,这个字段类似于一个指针,目前这个字段的值为154,表示的就是binlog当前的位置。我们每次执行dml操作,position都会改变。比如我们先来创建一个数据 test

在创建之前我们可以清一下binlog日志方便我们查看,可以使用 reset master。在生产环境中,这个操作是非常危险的,那么我们可以使用flush logs来处理,生成一个新的binlog文件。不管采用哪种方式,我们在测试的环境中,只要有一个新的binlog文件就可以了。生成了新的binlog文件之后,我们可以通过show master status 来查看状态

MySQL中binlog日志的使用方法

下面我们来执行一个dml语句,比如我们要创建一个test数据库

create database test;

然后我们来查看创建之后的状态,如下,我们发现position从154变成了313,也就是说我们的操作是在154到313之间,然后我们再来看binlog的内容。

MySQL中binlog日志的使用方法

我们截取154到313之间的binlog的内容如下:

# at 154 #170708 9:24:02 server id 12345 end_log_pos 219 CRC32 0x30763ffe Anonymous_GTID last_committed=0 sequence_number=1 SET @@SESSION.GTID_NEXT= 'ANONYMOUS'; # at 219 #170708 9:24:02 server id 12345 end_log_pos 313 CRC32 0x4d0140b3 Query thread_id=5 exec_time=0 error_code=0 SET TIMESTAMP=1499477042; SET @@session.pseudo_thread_id=5; SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1; SET @@session.sql_mode=1436549152; SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1; ; SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=8; SET @@session.lc_time_names=0; SET @@session.collation_database=DEFAULT; create database test ; SET @@SESSION.GTID_NEXT= 'AUTOMATIC'  ; DELIMITER ; # End of log file ; ;

我们可以看到,mysql做了很多的隐含的操作,细心的朋友会看到有这个一句:create database test;

下面我们来简单总结一下关于binlog:

binlog文件会随服务的启动创建一个新文件

通过flush logs 可以手动刷新日志,生成一个新的binlog文件

通过show master status 可以查看binlog的状态

通过reset master 可以清空binlog日志文件

通过mysqlbinlog 工具可以查看binlog日志的内容

通过执行dml,mysql会自动记录binlog

以上是“MySQL中binlog日志的使用方法”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网数据库频道!

您可能感兴趣的文档:

--结束END--

本文标题: MySQL中binlog日志的使用方法

本文链接: https://www.lsjlt.com/news/268678.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • MySQL中binlog日志的使用方法
    这篇文章主要介绍MySQL中binlog日志的使用方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!binlog 就是binary log,二进制日志文件,这个文件记录了MySQL所有的DML操作。通过binlog日...
    99+
    2023-06-14
  • MySQL中binlog日志如何使用
    本篇文章给大家分享的是有关MySQL中binlog日志如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。binlogbinlog用于记录数...
    99+
    2022-10-18
  • MySQL binlog日志乱码的处理方法
    这篇文章主要讲解了“MySQL binlog日志乱码的处理方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL binlog日志乱码的处理方法”吧!...
    99+
    2022-10-18
  • MySQL的binlog日志使用详解
    binlog 就是binary log,二进制日志文件,这个文件记录了MySQL所有的DML操作。通过binlog日志我们可以做数据恢复,增量备份,主主复制和主从复制等等。对于开发者可能对binlog并不怎么关注,但...
    99+
    2022-05-25
    MySQL binlog日志使用 MySQL binlog日志
  • 开启MySQL的binlog日志的方法步骤
    binlog 就是binary log,二进制日志文件,这个文件记录了mysql所有的dml操作。通过binlog日志我们可以做数据恢复,做主住复制和主从复制等等。对于开发者可能对binlog并不怎么关注,但是对于运...
    99+
    2022-05-12
    开启MySQL binlog日志 MySQL binlog开启
  • 怎么在mysql中使用Binlog日志
    今天就跟大家聊聊有关怎么在mysql中使用Binlog日志,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1、Statement基于SQL语句的复制,每一条会修改数据的sql都会记录在...
    99+
    2023-06-15
  • mysql中Binlog日志的作用是什么
    mysql中Binlog日志的作用是什么?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、说明MySQL的二进制日志binlog可以说是MySQL最重要的日志,...
    99+
    2023-06-15
  • 如何在mysql中启用Binlog日志
    如何在mysql中启用Binlog日志?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、一般来说开启binlog日志大概会有1%的性能损耗。启用binlog,通...
    99+
    2023-06-15
  • Binlog 日志处理工具如何在MySQL中使用
    本篇文章为大家展示了Binlog 日志处理工具如何在MySQL中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Canal定位:基于数据库增量日志解析,提供增量数据订阅&消费,目前主要支持...
    99+
    2023-06-14
  • java监听binlog日志的方法是什么
    在Java中,可以使用以下方法来监听binlog日志:1. 使用MySQL Connector/J:MySQL Connector/...
    99+
    2023-09-22
    java
  • mysql binlog日志的自动清理及手动删除的方法
    这篇文章主要介绍“mysql binlog日志的自动清理及手动删除的方法”,在日常操作中,相信很多人在mysql binlog日志的自动清理及手动删除的方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用...
    99+
    2022-10-18
  • MySQL使用binlog日志做数据恢复的实现
    MySQL的binlog日志是MySQL日志中非常重要的一种日志,记录了数据库所有的DML操作。通过binlog日志我们可以进行数据库的读写分离、数据增量备份以及服务器宕机时的数据恢复。 定期备份固然可以在服务器发生...
    99+
    2022-05-13
    MySQL binlog日志恢复 MySQL binlog 恢复
  • MySQL使用binlog日志做数据恢复的案例
    这篇文章主要介绍了MySQL使用binlog日志做数据恢复的案例,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。MySQL的binlog日志是MySQL日志中非常重要的一种日志...
    99+
    2023-06-14
  • MySQL二进制日志的使用方法
    这篇文章给大家分享的是MySQL二进制日志的使用方法,使用二进制日志可以实现异地容灾备份、读写分离、数据恢复等功能,通过这篇文章的总结,希望你能学会使用MySQL二进制日志。开启bin-log日志Mysql...
    99+
    2022-10-18
  • Django 中使用日志的方法
    目录1. 日志的意义2. django 中如何处理日志3. Python 中使用日志3.1 直接输出日志信息3.2 设置日志级别3.3 保存日志到文件3.4 设置编码3.5 覆盖日志...
    99+
    2022-11-11
  • 如何在Mysql数据库中使用命令清理binlog日志
    如何在Mysql数据库中使用命令清理binlog日志?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1、查看binlog日志my...
    99+
    2022-10-18
  • mysql日志恢复的方法
    mysql日志恢复的方法?这个问题可能是我们日常学习或工作经常见到的。希望通过这个问题能让你收获颇深。下面是小编给大家带来的参考内容,让我们一起来看看吧!mysql日志恢复的方法:首先指定恢复时间,代码为【...
    99+
    2022-10-18
  • Java日志的使用方法
    这篇文章将为大家详细讲解有关Java日志的使用方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Java可以用来干什么Java主要应用于:1. web开发;2. Android开发;3. 客户端开发;4....
    99+
    2023-06-14
  • 使用Navicat查看MySQL日志的具体方法
    下文主要给大家带来使用Navicat查看MySQL日志的具体方法,希望这些内容能够带给大家实际用处,这也是我编辑使用Navicat查看MySQL日志的具体方法这篇文章的主要目的。好了,废话不多说,大家直接看...
    99+
    2022-10-18
  • 一步教你掌握定期远程备份MYSQL binlog日志文件方法
    本篇文章给大家主要讲的是关于定期远程备份MYSQL binlog日志文件方法的内容,感兴趣的话就一起来看看这篇文章吧,相信看完定期远程备份MYSQL binlog日志文件方法对大家多少有点参考价值吧。&nb...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作