在CentOS系统中,可以通过配置logrotate
工具来实现PHP日志的自动清理。以下是详细步骤:
logrotate
大多数CentOS系统默认已经安装了logrotate
,如果没有安装,可以使用以下命令进行安装:
sudo yum install logrotate
logrotate
logrotate
的配置文件通常位于/etc/logrotate.conf
,但更常见的是使用/etc/logrotate.d/
目录下的特定配置文件。
你可以为每个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服务器,可以创建一个类似的配置文件:
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
}
你可以手动测试logrotate
配置是否正确:
sudo logrotate -f /etc/logrotate.conf
这个命令会强制logrotate
按照配置文件进行日志轮转。
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日志的自动清理机制了。