在CentOS系统中,可以通过配置logrotate工具来实现PHP日志的自动清理。以下是详细步骤:
1. 安装 logrotate
大多数CentOS系统默认已经安装了logrotate,如果没有安装,可以使用以下命令进行安装:
sudo yum install logrotate
2. 配置 logrotate
logrotate的配置文件通常位于/etc/logrotate.conf,但更常见的是使用/etc/logrotate.d/目录下的特定配置文件。
创建或编辑PHP日志的配置文件
你可以为每个PHP-FPM或Apache的日志文件创建一个单独的配置文件,或者将它们合并到一个配置文件中。以下是一个示例配置:
sudo vi /etc/logrotate.d/php-fpm
在这个文件中添加以下内容:
/var/log/php-fpm/*.log {
daily
missingok
rotate 7
compress
notifempty
create 640 root adm
sharedscripts
postrotate
if [ -f /var/run/php-fpm/php-fpm.pid ]; then
kill -USR2 `cat /var/run/php-fpm/php-fpm.pid`
fi
endscript
}
解释:
daily: 每天轮转日志。missingok: 如果日志文件丢失,不会报错。rotate 7: 保留7天的日志文件。compress: 压缩旧的日志文件。notifempty: 如果日志文件为空,则不轮转。create 640 root adm: 创建新的日志文件,权限为640,属主为root,属组为adm。sharedscripts: 只有在所有日志文件都轮转后才执行postrotate脚本。postrotate: 轮转后执行的脚本,这里用于通知PHP-FPM重新打开日志文件。
配置Apache的PHP日志
如果你使用的是Apache服务器,可以创建一个类似的配置文件:
sudo vi /etc/logrotate.d/apache-php
在这个文件中添加以下内容:
/var/log/httpd/access_log {
daily
missingok
rotate 7
compress
notifempty
create 640 root adm
}
/var/log/httpd/error_log {
daily
missingok
rotate 7
compress
notifempty
create 640 root adm
}
3. 测试配置
你可以手动测试logrotate配置是否正确:
sudo logrotate -f /etc/logrotate.conf
这个命令会强制logrotate按照配置文件进行日志轮转。
4. 设置定时任务
logrotate通常由系统的cron服务自动运行。你可以检查/etc/cron.daily/logrotate文件,确保它存在并且没有被禁用。
sudo vi /etc/cron.daily/logrotate
确保文件内容如下:
#!/bin/sh
/usr/sbin/logrotate /etc/logrotate.conf
EXITVALUE=$?
if [ $EXITVALUE != 0 ]; then
/usr/bin/logger -t logrotate "ALERT exited abnormally with [$EXITVALUE]"
fi
exit 0
这个脚本会在每天运行一次,检查并轮转日志文件。
通过以上步骤,你就可以在CentOS系统上设置PHP日志的自动清理机制了。