zoukankan      html  css  js  c++  java
  • Binlog详解

     

    一、介绍

      binlog, 即二进制文件,他记录了MySQL所有数据的变更,并以二进制的形式存储在磁盘上

     

    二、binlog模式

      binlog有三种模式:ROW(行模式),   Statement(语句模式),   Mixed(混合模式)

      ROW(行模式):记录那条数据修改了,注意:记录的是这条记录的全部数据,即使只更新了一个字段,binlog里也会记录所有字段的数据

                         优点:他不记录sql语句的上下文信息,日志内容会非常清楚的记录每条数据详细的变更细节,即使只更新了一个字段,binlog里也会记录所有字段的数据。

               缺点:binlog日志会非常大,mysql主从同步时,会产生大量磁盘IO

        

      Statement(语句模式):  每一条会修改数据的sql都会记录在binlog中。

              优点:不需要记录每一行的变化,减少了binlog日志量,节约了IO,提高性能。

              缺点:由于记录的只是执行语句,为了这些语句能在slave上正确运行,因此还必须记录每条语句在执行的时候的一些相关信息,以保证所有语句能在slave得到和在master端执行时候相同 的结果。另外mysql 的复制,像一些特定函数功能,slave可与master上要保持一致会有很多相关问题。

     

      Mixed(混合模式):在Mixed模式下,一般的语句修改使用statment格式保存binlog,如一些函数,statement无法完成主从复制的操作,则采用row格式保存binlog,MySQL会根据执行的每一条具体的sql语句来区分对待记录的日志形式,也就是在Statement和Row之间选择一种。

     

    三、开启和查看binlog

        1、查看mysql的binlog模式

    show variables like 'binlog_format'

     

      

     

      可以看到当前Mysql binlog模式为ROW

        

      2、首先查看mysql是否开启binlog同步功能

    show variables like 'log_bin';

     

        

      binlog功能已经开启,默认是关闭的,需要开启

     

      3、开启binlog, 通过修改/etc/my.inf文件开启binlog

    [mysqld]  # 这一行必须有,否则会出错
    #log_bin
    log-bin = mysql-bin #开启binlog
    binlog-format = ROW #选择row模式
    server_id = 12345 #配置mysql replication需要定义,不能和canal的slaveId重复

      4、binlog相关命令

    show binary logs   #获取binlog文件日志列表
    show master status # 查看当前正在写入的binlog文件
    show master logs # 查看master上的binlog文件
    show binlog events #查看第一个binlog文件内容
    show binlog events in 'mysql-bin.000002' # 查看指定binlog文件内容, 如:查看mysql-bin.000002文件内容
    命令格式:show binlog events [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count]


  • 相关阅读:
    Linux编译安装中configure、make和make install各自的作用
    转载的 Linux下chkconfig命令详解
    MYSQL主从不同步延迟原理分析及解决方案(摘自http://www.jb51.net/article/41545.htm)
    mysql主从延迟(摘自http://www.linuxidc.com/Linux/2012-02/53995.htm)
    http://ninghao.net/video/1554不错的学习网址
    javascript 内置对象和方法
    javascript 函数
    javascript 基础
    css z-index
    css 透明度
  • 原文地址:https://www.cnblogs.com/jsnr-tdyd/p/9053109.html
Copyright © 2011-2022 走看看