二进制日志

  • 记录导致数据改变或潜在导致数据改变的SQL语句
  • 记录已提交的日志
  • 不依赖于存储引擎类型
  • 功能:通过“重放”日志文件中的事件来生成数据副本
  • 注意:建议二进制日志和数据文件分开存放

二进制日志记录三种格式

  • 基于“语句”记录:statement,记录语句,默认模式( MariaDB 10.2.3 版本以下 ),日志量较少
  • 基于“行”记录:row,记录数据,日志量较大
  • 混合模式:mixed, 让系统自行判定该基于哪种方式进行,默认模式( MariaDB 10.2.4及版本以上)

格式配置

    • MariaDB [hellodb]> show variables like 'binlog_format';
    • +---------------+-------+
    • | Variable_name | Value |
    • +---------------+-------+
    • | binlog_format | MIXED |
    • +---------------+-------+
    • 1 row in set (0.001 sec)

二进制日志文件的构成

  • 有两类文件
    • 日志文件:mysql|mariadb-bin.文件名后缀,二进制格式

      如: mariadb-bin.000001
    • 索引文件:mysql|mariadb-bin.index,文本格式

二进制日志相关的服务器变量:

  • sql_log_bin=ON|OFF:#是否记录二进制日志,默认ON
  • log_bin=/PATH/BIN_LOG_FILE:#指定文件位置;默认OFF,表示不启用二进制日志功能,上述两项都开

    启才可
  • binlog_format=STATEMENT|ROW|MIXED:#二进制日志记录的格式,默认STATEMENT
  • max_binlog_size=1073741824:#单个二进制日志文件的最大体积,到达最大值会自动滚动,默认为1G
    • 说明:文件达到上限时的大小未必为指定的精确值
  • sync_binlog=1|0:#设定是否启动二进制日志即时同步磁盘功能,默认0,由操作系统负责同步日志到磁盘
  • expire_logs_days=N:#二进制日志可以自动删除的天数。 默认为0,即不自动删除

二进制日志相关配置

查看mariadb自行管理使用中的二进制日志文件列表,及大小

  • SHOW {BINARY | MASTER} LOGS

查看使用中的二进制日志文件

  • SHOW MASTER STATUS

查看二进制文件中的指定内容

  • show binlog events in 'mysql-bin.000001' from 6516 limit 2,3

mysqlbinlog:二进制日志的客户端命令工具

mysqlbinlog [OPTIONS] log_file…
--start-position=# 指定开始位置
--stop-position=#
--start-datetime= #时间格式:YYYY-MM-DD hh:mm:ss
--stop-datetime=
--base64-output[=name] 例如: mysqlbinlog --start-position=678 --stop-position=752 /var/lib/mysql/mariadbbin.000003 -v

二进制日志事件的格式:

# at 328
#151105 16:31:40 server id 1 end_log_pos 431 Query thread_id=1
exec_time=0 error_code=0
use `mydb`/*!*/;
SET TIMESTAMP=1446712300/*!*/;
CREATE TABLE tb1 (id int, name char(30))
/*!*/;
事件发生的日期和时间:151105 16:31:40
事件发生的服务器标识:server id 1
事件的结束位置:end_log_pos 431
事件的类型:Query
事件发生时所在服务器执行此事件的线程的ID:thread_id=1
语句的时间戳与将其写入二进制文件中的时间差:exec_time=0
错误代码:error_code=0

清除指定二进制日志

PURGE { BINARY | MASTER } LOGS { TO 'log_name' | BEFORE datetime_expr }
例如
PURGE BINARY LOGS TO 'mariadb-bin.000003'; #删除mariadb-bin.000003之前的日志
PURGE BINARY LOGS BEFORE '2017-01-23';
PURGE BINARY LOGS BEFORE '2017-03-22 09:25:30';

删除所有二进制日志,index文件重新记数

RESET MASTER [TO #]; #删除所有二进制日志文件,并重新生成日志文件,文件名从#开始记数,默认从
1开始,一般是master主机第一次启动时执行,MariaDB10.1.6开始支持TO #

最新文章

  1. 用javascript写星际飞机大战游戏
  2. jdk安装及环境变量配置
  3. android 开发学习笔记 (一)
  4. Realitymining 数据集简单介绍与使用
  5. 【原创】.NET读写Excel工具Spire.Xls使用(2)Excel文件的控制
  6. Effective C++ -----条款07:为多态基类声明virtual析构函数
  7. 【bzoj1853】 Scoi2010—幸运数字
  8. LINQ to XML 实战
  9. 【同行说技术】swift最全学习资料汇集(一)
  10. PL/SQL Developer简单使用
  11. java zip解压
  12. 微信小程序页面跳转方法和携带参数详解
  13. JMeter—常见问题(十四)
  14. python_09 文件处理流程,文件操作方法
  15. 进入正在运行的 docker 容器(docker container)
  16. L2-002. 链表去重(数组模拟)
  17. 如何用input标签上传多个图片并回显
  18. &符号 (弃用引用传参了,不要用!!)
  19. spring-service.xml 模板
  20. IOS6 IOS7 Mapkit draw Rout(地图划线)

热门文章

  1. mybatis低版本jsr310(LocalDateTime,LocalDate等) Joda Time支持
  2. Java内部类(5):应用例
  3. 导入现有java工程
  4. vue工程中,如何查询用户访问的地理位置 + vue中的jsonp
  5. 性能排查--CPU占用高
  6. Opencv 简单视频播放器
  7. GIP画图
  8. centOS重启网络服务报错
  9. SQL Server 验证身份证合法性函数(使用VBScript.RegExp)
  10. 基于 CentOS 7 搭建 GitLab