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       查询总条数(不指定就是所有行)

5. 通过binlog恢复数据实例