mysql的二进制日志

主要内容来自于《深入浅出MySQL》一书的第26章

设置二进制日志

1
[mysqld]
2
log-bin=mysql-bin     #二进制日志的文件名
3
binlog_format=mixed   #日志记录格式
日志记录格式有STATEMENT、ROW、MIXED(默认)
读取二进制日志
1
mysqlbinlog binlog_filename
2
mysqlbinlog mysql-bin.000001
删除二进制日志
1.删除所有的二进制日志
1
mysql> RESET MASTER;
2
Query OK, 0 rows affected (0.02 sec)
RESET MASTER,该命令将会删除所有的BINLOG日志,新日志编号从“000001”开始。
2.删除指定位置开始的二进制日志
1
mysql> PURGE BINARY LOGS TO 'mysql-bin.000010';    #指定的二进制文件之前的删除掉
2
mysql> PURGE BINARY LOGS BEFORE '2017-05-01 00:00:00';  #指定日期之前的二进制日志删除掉
3.设置参数--expire_logs_days=#,此参数的含义是设置日志的国企天数,过了指定的天数之后日志将会被自动删除,这样有利于减少DBA管理日志的工作量。
1
[mysqld]
2
expire_logs_day=60     #60天之前的binlog日志会自动删除
查看一下
1
mysql> show variables like '%logs%';
2
+------------------+-------+
3
| Variable_name    | Value |
4
+------------------+-------+
5
| expire_logs_days | 60    |
6
+------------------+-------+
7
1 row in set (0.00 sec)
结果可以看出已经生效了。
其它选项
--binlog-do-db=db_name:该选项告诉主服务器,如果当前的数据库(即USE选定的数据库)是db_name,应将更新记录到二进制日志中。其他没有显示指定的数据库更新将被忽略,不记录在日志中。
--binlog-ignore-db=db_name:该选项告诉主服务器,如果当前的数据库 (即USE选定的数据库)是db_name,不应将更新记录到二进制日志中,其他没有显示指定的数据库更新都将进行记录。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值