Ubuntu下PHP日志清理方法
PHP日志的位置取决于Web服务器和PHP运行模式,常见路径如下:
/var/log/apache2/access.log(访问日志)、/var/log/apache2/error.log(错误日志)/var/log/nginx/access.log(访问日志)、/var/log/nginx/error.log(错误日志)/var/log/php-fpm.log(默认日志)、/var/log/php7.x-fpm.log(带版本号的日志,如PHP 7.4)使用truncate命令将日志文件大小截断为0字节,不会删除文件本身,避免影响依赖日志的服务:
# Apache示例
sudo truncate -s 0 /var/log/apache2/access.log
sudo truncate -s 0 /var/log/apache2/error.log
# Nginx示例
sudo truncate -s 0 /var/log/nginx/access.log
sudo truncate -s 0 /var/log/nginx/error.log
# PHP-FPM示例
sudo truncate -s 0 /var/log/php-fpm.log
若需彻底删除旧日志,可先用rm删除文件,再用touch创建空文件(需确保目录权限正确):
# Apache示例
sudo rm /var/log/apache2/access.log
sudo rm /var/log/apache2/error.log
sudo touch /var/log/apache2/access.log
sudo touch /var/log/apache2/error.log
sudo chown www-data:www-data /var/log/apache2/*.log # 确保Apache用户有写入权限
Logrotate是Ubuntu自带的日志管理工具,可实现定期轮转、压缩、删除旧日志,避免手动操作。
PHP相关的日志轮转配置通常位于:
/etc/logrotate.d/apache2/etc/logrotate.d/nginx/etc/logrotate.d/php-fpm(部分系统可能集成在PHP包中)若需立即清理旧日志,可强制运行Logrotate:
sudo logrotate -f /etc/logrotate.d/apache2 # 强制轮转Apache日志
sudo logrotate -f /etc/logrotate.d/php-fpm # 强制轮转PHP-FPM日志
编辑对应配置文件(如/etc/logrotate.d/php-fpm),添加以下内容(以PHP-FPM为例):
/var/log/php-fpm/*.log {
daily # 每天轮转一次
missingok # 若日志文件不存在也不报错
rotate 7 # 保留最近7天的日志
compress # 压缩旧日志(节省空间)
delaycompress # 延迟压缩(如第8天压缩第1天的日志)
notifempty # 若日志为空则不轮转
create 0640 www-data adm # 创建新日志文件,权限640,属主www-data,属组adm
sharedscripts # 所有日志轮转完成后执行脚本
postrotate
if [ -f /run/php/php7.4-fpm.pid ]; then # 根据PHP版本调整PID文件路径
kill -USR2 `cat /run/php/php7.4-fpm.pid` # 通知PHP-FPM重新打开日志文件
fi
endscript
}
若需定期自动清理,可通过cron定时运行Logrotate或清理命令。
crontab -e
例如,每天凌晨2点自动轮转所有日志(包括PHP日志):
0 2 * * * /usr/sbin/logrotate /etc/logrotate.conf
或仅清理PHP-FPM日志(每天凌晨1点):
0 1 * * * /usr/bin/truncate -s 0 /var/log/php-fpm.log
sudo,确保对日志文件有写入权限;修改配置后需重启对应服务(如sudo systemctl restart apache2)。cp /var/log/apache2/error.log ~/error_log_backup_$(date +%F).log)。rm -rf命令,防止删除系统关键文件。通过上述方法,可有效管理Ubuntu系统中的PHP日志,保持磁盘空间充足并便于问题排查。