mysql binlog日志功能说明和开启
1. binlog 基本认识
MySQL的二进制日志可以说是MySQL最重要的日志了,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日志是事务安全型的。
一般来说开启二进制日志大概会有1%的性能损耗。二进制有两个最重要的使用场景:
a) MySQL Replication在Master端开启binlog,Mster把它的二进制日志传递给slaves来达到master-slave数据一致的目的。
b) 自然就是数据恢复了,通过使用mysqlbinlog工具来使恢复数据。
二进制日志包括两类文件:
二进制日志索引文件(文件名后缀为.index)用于记录所有的二进制文件;
二进制日志文件(文件名后缀为.00000*)记录数据库所有的DDL和DML(除了数据查询语句)语句事件;
2. 开启binlog日志
2.1 开启binlog
vi /etc/my.cnf
# 在mysql 下添加如下
log-bin=mysql-bin
server-id=1
2.2 查看mysql日志的是否打开
mysql> show variables like 'log_%';
Variable_name Value
-------------------------------------- ---------------------
log_bin OFF -- off 标识未开启
log_bin_basename
log_bin_index
log_bin_trust_function_creators OFF
log_bin_use_v1_row_events OFF
log_builtin_as_identified_by_password OFF
log_error /var/log/mysqld.log
log_error_verbosity 3
log_output FILE
log_queries_not_using_indexes OFF
log_slave_updates OFF
log_slow_admin_statements OFF
log_slow_slave_statements OFF
log_statements_unsafe_for_binlog ON
log_syslog OFF
log_syslog_facility daemon
log_syslog_include_pid ON
log_syslog_tag
log_throttle_queries_not_using_indexes 0
log_timestamps UTC
log_warnings 2
3. 常用binlog日志操作命令
3.1 查看所有binlog日志列表
mysql> show master logs;
3.2 查看master状态,即最后(最新)一个binlog日志的编号名称,及其最后一个操作事件pos结束点(Position)值
mysql> show master status;
3.3.刷新log日志,自此刻开始产生一个新编号的binlog日志文件
mysql> flush logs;
注:每当mysqld服务重启时,会自动执行此命令,刷新binlog日志;在mysqldump备份数据时加 -F 选项也会刷新binlog日志;
3.4 重置(清空)所有binlog日志
mysql> reset master;
4. 查看某个binlog日志内容,常用有两种方式:
4.1 使用mysqlbinlog自带命令查看
#/usr/bin/mysqlbinlog --no-defaults /var/lib/mysql/mysql-bin.000002
注:
a) 不推荐命令查看,太乱了。可以使用下面的方法查看
b) 命令行查看过程中,有可能会因为版本或者设置的不同报错, 需要加上 “--no-defaults”选项,忽略本地
c) binlog是二进制文件,普通文件查看器cat more vi等都无法打开,必须使用自带的 mysqlbinlog 命令查看
4.2 使用client中查看:
mysql> show binlog events [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count];
选项解析:
IN 'log_name' 指定要查询的binlog文件名(不指定就是第一个binlog文件)
FROM pos 指定从哪个pos起始点开始查起(不指定就是从整个文件首个pos点开始算)
LIMIT [offset,] 偏移量(不指定就是0)
row_count 查询总条数(不指定就是所有行)