MySQL bin-log 日志清理方式
2023-09-11 14:19:34 时间
MySQL bin-log 作用
1.数据恢复:如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失。
2.主从服务器之间同步数据:主服务器上所有的操作都在记录日志中,从服务器可以根据该日志来进行,以确保两个同步。
3.在什么时间会删除过期日志?
每次进行 LOG flush的时会自动删除过期的日志,那么什么时间才能触发log flush,手册上的解释为:
- 重启 MySQL
- bin-log 文件大小达到参数 max_binlog_size 限制;
- 手工执行清理命令
自动清理方法1:(修改配置文件和在mysql内设置参数可无需重启服务)
vim my.cnf
expire_logs_days = 7 // 表示日志保留7天,超过7天则设置为过期的
# mysql -u root -p > show binary logs; > show variables like '%log%'; > set global expire_logs_days = 7;
手动清理方法2:(推荐)
如果没有主从复制,可以通过下面的命令重置数据库日志,清除之前的日志文件:
reset master
但是如果存在复制关系,应当通过 PURGE 的名来清理 bin-log 日志,语法如下:
# mysql -u root -p
> purge master logs to 'mysql-bin.010’; //清除mysql-bin.010日志
> purge master logs before '2016-02-28 13:00:00'; //清除2016-02-28 13:00:00前的日志
> purge master logs before date_sub(now(), interval 3 day); //清除3天前的bin日志
注意,不要轻易手动去删除binlog,会导致binlog.index和真实存在的binlog不匹配,而导致expire_logs_day失效
相关文章
- Shell离线脚本安装mysql、更新密码
- 【MySQL高级】Mysql并发参数调整及常用SQL技巧
- Mysql执行大文件sql语句 -- 未测试
- MySQL无法启动报 Error: could not open single-table tablespace file ./mysql/innodb_table_sta
- MySQL事务日志和二进制日志(redo log、undo log、binlog)
- MySQL 聚簇索引与非聚簇索引的理解
- 【MySQL进阶-07】深入理解mysql性能优化以及解决慢查询问题
- MySQL root修改普通用户密码及Mysql 修改root密码
- .NET/Mysql-petatoco连接mysql数据库
- MySQL 中隔离级别 RC 与 RR 的区别
- 转 【MySQL】常用拼接语句 shell 下执行mysql 命令
- Windows 免安装版mysql,适用于版本MySQL 5.7.7及以上,快速配置教程
- MySQL bin-log 日志清理方式
- mysql--二进制日志(bin-log)三种格式介绍及分析
- Mysql error.log报错:Error: Table “mysql”.“innodb_table_stats” not found
- 【mysql连接与mysqldump】INFORMATION_SESSION_VARIABLES feature is disabled
- Mysql中出现please use mysql_upgrade to fix this errot解决的办法
- mysql日志文件开启及详解:General_log 和 Binlog
- MySQL操作基础之DDL语句
- [Mysql] WITH ROOLUP