mysql 日志时间格式_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')

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值