博客
关于我
mysql的logrotate脚本
阅读量:788 次
发布时间:2023-02-13

本文共 1487 字,大约阅读时间需要 4 分钟。

随着业务规模的扩大和时间的推移,MySQL的日志文件必然会呈指数级增长,日志文件的体积也会不断膨胀。为了有效管理这些日志文件,通常需要使用logrotate进行轮替管理。MySQL官方提供的二进制包中包含了用于日志轮转的logrotate脚本,位于support-files文件夹中,文件名为mysql-log-rotate。不过,这个脚本需要经过适当修改后才能正常使用。

以下是修改后的MySQL日志轮转脚本内容:

#!/bin/sh## This logname can be set in /etc/my.cnf by setting the variable "err-log"# in the [safe_mysqld] section as follows:##  [safe_mysqld]##  err-log=/usr/local/mysql/data/mysqld.log## If the root user has a password, you need to create a# /root/.my.cnf configuration file with the following content:##  [mysqladmin]##  user = root##  password = # 
## host = yourhost## port = 3307#
## This ensures that /root/.my.cnf is only readable by root.#{ create 600 mysql mysql \ -- notifies missingok daily rotate 3 compress postrotate { if test -x /usr/local/mysql/bin/mysqladmin \ && /usr/local/mysql/bin/mysqladmin ping > /dev/null \ then /usr/local/mysql/bin/mysqladmin flush-logs fi }}

将修改后的logrotate脚本复制到/etc/logrotate.d/mysqld文件中。需要注意的是,如果你的MySQL根用户设置了密码,你需要在/root/.my.cnf文件中添加相应的配置信息,以便mysqladmin能够正常使用。

/root/.my.cnf文件中添加以下内容:

[root@localhost ~]# vim .my.cnf[root@localhost ~]# 
[mysqladmin] user = root password = host = yourhost port = 3307

请将<secret>部分中的内容替换为你的实际密码信息。这样配置后,logrotate脚本就可以正常地执行日志轮转操作了。

需要注意的是,如果日志文件为空,logrotate会自动忽略该操作。日志轮转操作每天执行3次,并且如果发现MySQL服务未启动,会自动调用flush-logs命令完成日志刷新。

通过以上方法,你可以轻松地实现MySQL日志的自动轮转管理,避免日志文件占用过多存储空间,并确保服务器运行更加稳定。

转载地址:http://wvdfk.baihongyu.com/

你可能感兴趣的文章
Mysql学习总结(49)——从开发规范、选型、拆分到减压
查看>>
Mysql学习总结(4)——MySql基础知识、存储引擎与常用数据类型
查看>>
Mysql学习总结(56)——MySQL用户管理和权限设置
查看>>
Mysql学习总结(58)——深入理解Mysql的四种隔离级别
查看>>
Mysql学习总结(59)——数据库分库分表策略总结
查看>>
Mysql学习总结(60)——并发量大、数据量大的互联网业务数据库设计规范总结
查看>>
Mysql学习总结(61)——MySQL优化之DBA级优化整理汇总
查看>>
Mysql学习总结(64)——Mysql配置文件my.cnf各项参数解读
查看>>
Mysql学习总结(65)——项目实战中常用SQL实践总结
查看>>
Mysql学习总结(66)——设置MYSQL数据库编码为UTF-8
查看>>
Mysql学习总结(68)——MYSQL统计每天、每周、每月、每年数据 SQL 总结
查看>>
Mysql学习总结(69)——Mysql EXPLAIN 命令使用总结
查看>>
Mysql学习总结(6)——MySql之ALTER命令用法详细解读
查看>>
Mysql学习总结(70)——MySQL 优化实施方案
查看>>
Mysql学习总结(71)——MySQL 重复记录查询与删除总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>