暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySQL binlog

测试备忘录 2021-06-09
240

MySQL中一般有以下几种日志:

日志类型写入日志的信息
错误日志记录在启动,运行或停止mysqld时遇到的问题
通用查询日志记录建立的客户端连接和执行的语句
二进制日志记录更改数据的语句
中继日志从复制主服务器接收的数据更改
慢查询日志记录所有执行时间超过 long_query_time
 秒的所有查询或不使用索引的查询
DDL日志(元数据日志)元数据操作由DDL语句执行
     MySQL 的二进制日志 binlog 记录了所有的 DDL
 和 DML
 语句(除了数据查询语句select、show等),以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日志是事务安全型的。binlog 的主要目的是复制和恢复。

Binlog日志的两个重要的使用场景

  • MySQL主从复制:MySQL Replication在Master端开启binlog,Master把它的二进制日志传递给slaves来达到master-slave数据一致的目的

  • 数据恢复:通过使用 mysqlbinlog工具来使恢复数据

启用 Binlog

    一般来说开启binlog日志会有一定的的性能损耗。

    启用binlog,通过配置 /etc/my.cnf
 或 /etc/mysql/mysql.conf.d/mysqld.cnf
 配置文件的 log-bin
 选项:

    在配置文件中加入 log-bin
 配置,表示启用binlog,如果没有给定值,写成 log-bin=
,则默认名称为主机名。(注:名称若带有小数点,则只取第一个小数点前的部分作为名称)

[mysqld]
log-bin=my-binlog-name

    也可以通过 SET SQL_LOG_BIN=1
 命令来启用 binlog,通过 SET SQL_LOG_BIN=0
 命令停用 binlog。启用 binlog 之后须重启MySQL才能生效。

常用的Binlog操作命令

# 是否启用binlog日志
show variables like 'log_bin';

# 查看详细的日志配置信息
show global variables like '%log%';

# mysql数据存储目录
show variables like '%dir%';

# 查看binlog的目录
show global variables like "%log_bin%";

# 查看当前服务器使用的biglog文件及大小
show binary logs;

# 查看最新一个binlog日志文件名称和Position
show master status;

# 事件查询命令
# IN 'log_name' :指定要查询的binlog文件名(不指定就是第一个binlog文件)
# FROM pos :指定从哪个pos起始点开始查起(不指定就是从整个文件首个pos点开始算)
# LIMIT [offset,] :偏移量(不指定就是0)
# row_count :查询总条数(不指定就是所有行)
show binlog events [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count];

# 查看 binlog 内容
show binlog events;

# 查看具体一个binlog文件的内容 (in 后面为binlog的文件名)
show binlog events in 'master.000003';

# 设置binlog文件保存事件,过期删除,单位天
set global expire_log_days=3;

# 删除当前的binlog文件
reset master;

# 删除slave的中继日志
reset slave;

# 删除指定日期前的日志索引中binlog日志文件
purge master logs before '2019-03-09 14:00:00';

# 删除指定日志文件
purge master logs to 'master.000003';

最后修改时间:2021-06-11 15:27:23
文章转载自测试备忘录,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论