mysql的日志格式分日志分析

1 日志分为三种格式

statement 基于语句的

row 基于行的

mixed 复合的

 

区别:
基于语句的 简单,精悍,服务器会将数据修改事件以SQL语句的形式写入二进制,内容比较容易理解

语句行的 对要修改哪些数据  提供了跟精细的控制,但是不容易理解,出现这种格式的原因在于,有些语句可能不够明确,在主服务器和从服务器上执行可能会出现不同的效果

基于mixed  服务器会根据最适当的时候切换使用基于语句或者基于行的格式

 

2 如何查看当前系统的格式


mysql> show global variables like '%format%';

 

3 如何修改

暂时修改  当前会话或别的会话

mysql> set session binlog_format='mixed';

mysql> set global binlog_format='mixed';

重启mysqld 就不生效了

永久生效

写入my.cnf 的配置文件当中

binlog_format=

 

4 演示的不同格式效果

[root@web1 logs]# mysqlbinlog master_bin.000003 和 不断set 修改 format_log 

mysql> show binlog events in 'master_bin.000003';  简便的查看每个pos期间执行的操作内容

基于statement 语句的

# at 781
#141116 22:40:42 server id 100 end_log_pos 897 CRC32 0x63842d06 Query thread_id=3 exec_time=0 error_code=0
SET TIMESTAMP=1416148842/*!*/;
insert student (id,name) values (1,'andy')
/*!*/;

 

| master_bin.000003 |  781 | Query       |       100 |         897 | use `mydb`; insert student (id,name) values (1,'andy')  

 

基于row的

# at 1254
#141116 22:43:38 server id 100 end_log_pos 1303 CRC32 0x115dc0d4 Write_rows: table id 70 flags: STMT_END_F

BINLOG '
GrhoVBNkAAAANQAAAOYEAAAAAEYAAAAAAAEABG15ZGIAB3N0dWRlbnQAAgP+Av4UA9TLV8c=
GrhoVB5kAAAAMQAAABcFAAAAAEYAAAAAAAEAAgAC//wCAAAACGN1aWRlaHVh1MBdEQ==

其实这条执行的操作也是一个insert 语句但是 我们无法阅读

| master_bin.000003 | 1254 | Write_rows  |       100 |        1303 | table_id: 70 flags: STMT_END_F 

 

基于mixed的 这里它自动选择了合适的 statement 基于语句的

| master_bin.000003 | 1492 | Query       |       100 |        1615 | use `mydb`; insert student (id,name) values (4,'zhangxueyou')

 

posted @ 2014-11-16 23:10  小小龟侠  阅读(331)  评论(0编辑  收藏  举报