如何配置PHP日志轮转
配置PHP日志轮转可以通过多种方式实现,具体取决于你的操作系统和PHP的配置方式。以下是一些常见的方法:
方法一:使用 logrotate
工具(适用于Linux系统)
logrotate
是一个用于管理日志文件的工具,可以自动轮转、压缩和删除旧日志文件。以下是如何配置 logrotate
来管理PHP日志文件的步骤:
-
创建或编辑
logrotate
配置文件: 通常,logrotate
的配置文件位于/etc/logrotate.d/
目录下。你可以创建一个新的配置文件或编辑现有的文件。sudo nano /etc/logrotate.d/php-fpm
-
添加配置内容: 在文件中添加以下内容,根据你的实际情况调整路径和选项:
/var/log/php-fpm/*.log { daily missingok rotate 7 compress notifempty create 640 root adm }
解释:
daily
: 每天轮转一次日志文件。missingok
: 如果日志文件不存在,不会报错。rotate 7
: 保留7个轮转的日志文件。compress
: 压缩旧的日志文件。notifempty
: 如果日志文件为空,不进行轮转。create 640 root adm
: 创建新的日志文件,权限为640,属主为root,属组为adm。
-
测试配置: 你可以手动测试
logrotate
配置是否正确:sudo logrotate -f /etc/logrotate.d/php-fpm
方法二:使用 cron
定时任务
如果你不想使用 logrotate
,也可以通过 cron
定时任务来手动轮转日志文件。
-
编辑
cron
任务: 打开当前用户的crontab
文件:crontab -e
-
添加定时任务: 添加以下行来每天午夜轮转日志文件:
0 0 * * * /usr/bin/find /var/log/php-fpm/*.log -type f -name "*.log" -exec gzip {} \; && /usr/bin/find /var/log/php-fpm/ -type f -name "*.log.gz" -exec mv {} {}.1 \; && touch /var/log/php-fpm/access.log
解释:
0 0 * * *
: 每天午夜执行。/usr/bin/find /var/log/php-fpm/*.log -type f -name "*.log" -exec gzip {} \;
: 压缩所有.log
文件。/usr/bin/find /var/log/php-fpm/ -type f -name "*.log.gz" -exec mv {} {}.1 \;
: 将压缩后的文件重命名为.1
。touch /var/log/php-fpm/access.log
: 创建一个新的空日志文件。
方法三:使用PHP-FPM内置日志轮转
如果你使用的是PHP-FPM,可以在 php-fpm.conf
或 www.conf
文件中配置日志轮转。
-
编辑配置文件: 打开
php-fpm.conf
或www.conf
文件:sudo nano /etc/php/7.x/fpm/pool.d/www.conf
-
添加或修改日志轮转配置: 找到以下行并添加或修改:
catch_workers_output = yes php_admin_value[error_log] = /var/log/php-fpm/error.log php_admin_flag[log_errors] = on php_admin_value[memory_limit] = 32M php_admin_value[max_execution_time] = 60 php_admin_value[date.timezone] = UTC
然后添加日志轮转配置:
php_admin_value[error_log] = /var/log/php-fpm/error.log php_admin_flag[log_errors] = on php_admin_value[memory_limit] = 32M php_admin_value[max_execution_time] = 60 php_admin_value[date.timezone] = UTC php_admin_value[log_rotations_max] = 7 php_admin_value[log_rotation_time] = daily
解释:
log_rotations_max
: 保留的日志文件数量。log_rotation_time
: 日志轮转的时间间隔。
-
重启PHP-FPM服务: 保存文件并重启PHP-FPM服务:
sudo systemctl restart php7.x-fpm
通过以上方法,你可以有效地配置PHP日志轮转,确保日志文件不会无限增长,同时保留足够的历史记录。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权请联系我们,一经查实立即删除!