centos

如何配置PHP日志轮转

小樊
56
2025-07-08 18:04:08
栏目: 编程语言

配置PHP日志轮转可以通过多种方式实现,具体取决于你的操作系统和PHP的配置方式。以下是一些常见的方法:

方法一:使用 logrotate 工具(适用于Linux系统)

logrotate 是一个用于管理日志文件的工具,可以自动轮转、压缩和删除旧日志文件。以下是如何配置 logrotate 来管理PHP日志文件的步骤:

  1. 创建或编辑 logrotate 配置文件: 通常,logrotate 的配置文件位于 /etc/logrotate.d/ 目录下。你可以创建一个新的配置文件或编辑现有的文件。

    sudo nano /etc/logrotate.d/php-fpm
    
  2. 添加配置内容: 在文件中添加以下内容,根据你的实际情况调整路径和选项:

    /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。
  3. 测试配置: 你可以手动测试 logrotate 配置是否正确:

    sudo logrotate -f /etc/logrotate.d/php-fpm
    

方法二:使用 cron 定时任务

如果你不想使用 logrotate,也可以通过 cron 定时任务来手动轮转日志文件。

  1. 编辑 cron 任务: 打开当前用户的 crontab 文件:

    crontab -e
    
  2. 添加定时任务: 添加以下行来每天午夜轮转日志文件:

    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.confwww.conf 文件中配置日志轮转。

  1. 编辑配置文件: 打开 php-fpm.confwww.conf 文件:

    sudo nano /etc/php/7.x/fpm/pool.d/www.conf
    
  2. 添加或修改日志轮转配置: 找到以下行并添加或修改:

    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: 日志轮转的时间间隔。
  3. 重启PHP-FPM服务: 保存文件并重启PHP-FPM服务:

    sudo systemctl restart php7.x-fpm
    

通过以上方法,你可以有效地配置PHP日志轮转,确保日志文件不会无限增长,同时保留足够的历史记录。

0
看了该问题的人还看了