删除mysql日志文件

show binary logs;
show variables like 'expire_logs_days';
set global expire_logs_days = 30;设置日志过期时间
purge binary logs before '2019-12-19 13:09:51';

### 如何正确删除MySQL日志文件 #### 删除二进制日志 (Binary Logs) 为了安全地删除 MySQL 的二进制日志,可以使用 `PURGE BINARY LOGS` 命令。此命令允许管理员清除不再需要的旧二进制日志文件,从而释放磁盘空间并保持系统的整洁。 通过指定一个目标日志文件名称,所有早于此文件的日志会被删除,但不会影响到所指明的那个文件本身及其后续文件。例如: ```sql PURGE BINARY LOGS TO 'mysql-bin.000003'; ``` 这条语句会删除直到 `mysql-bin.000003` 之前的所有二进制日志文件,而不包括 `mysql-bin.000003` 自身[^1]。 另一种方式是基于时间戳来清理过期的日志: ```sql PURGE BINARY LOGS BEFORE '2023-10-01 00:00:00'; ``` 这样能够移除创建日期早于给定时间的所有二进制日志文件[^5]。 需要注意的是,如果执行了上述命令却未见预期中的某些日志被成功删除,则可能是由于存在正在使用的或者锁定状态下的日志文件等原因造成的[^3]。 #### 清理通用查询日志 (General Query Log) 当启用了 MySQL 的通用查询日志功能后,在默认存储路径 `/var/lib/mysql/` 下会产生名为 `hostname.log` 的文件(其中 hostname 是服务器主机名)。随着时间推移,这个文件可能会变得极其庞大,因此定期维护它是必要的[^2]。 一种简单有效的做法就是停止服务进程后再手动重命名或清空原日志文件内容再重启服务;不过更推荐的方式是在不停机的情况下利用 shell 脚本配合轮转工具如 logrotate 来实现自动化管理。比如下面的例子展示了如何快速截断现有日志而无需中断数据库运行: ```bash echo -n "" > /path/to/logfile ``` 这里假设已知确切位置以及权限许可的前提下可以直接覆盖原有数据为空字符串即可完成即时瘦身效果[^2]。 另外值得注意的一点在于对于任何类型的日志操作前都应该确认好当前环境配置参数诸如 binlog_format 和 sync_binlog 等设置合理与否因为它们直接影响性能表现同时也关系着灾难恢复能力等方面考量因素[^4]。 最后提醒一点关于物理层面的实际销毁动作务必小心谨慎以免误伤重要资料造成不可逆损失! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值