ThinkPHP的日志管理需通过配置文件调整,Ubuntu环境下需确保路径权限正确。
config/config.php(或.env环境变量文件)中,关键参数包括:
file(文件存储),支持syslog(系统日志)等;path参数指定日志目录(如runtime/log/),需确保Ubuntu用户(如www-data)对该目录有写入权限(chmod -R 755 runtime/log/);level参数控制记录级别(DEBUG、INFO、WARN、ERROR、FATAL),生产环境建议设为ERROR或WARN以减少日志量;format参数自定义日志输出格式(如{date} [{time}] {level} {message})。config/config.php):'log' => [
'type' => 'file', // 日志驱动
'path' => './runtime/log/', // 存储路径(相对项目根目录)
'level' => ['error', 'warn'], // 仅记录ERROR和WARN级别
'expire' => 7, // 日志保留7天(自动清理)
],
若使用.env文件(推荐),可添加:LOG_TYPE=file
LOG_PATH=./runtime/log/
LOG_LEVEL=error,warn
ThinkPHP提供Log门面类统一记录日志,支持分类记录(便于后续筛选)。
use think\facade\Log;
Log::info('用户登录成功', ['user_id' => 1001]); // INFO级别
Log::error('数据库连接失败', ['host' => 'localhost']); // ERROR级别
notice级别),需手动开启:Log::sql('SELECT * FROM users WHERE id = 1'); // 自动记录到SQL分类
DEBUG):Log::init(['level' => ['debug']]); // 仅记录DEBUG及以上级别
runtime/log/目录(如runtime/log/202509.log),使用Ubuntu命令行工具查看:# 查看最新日志(分页)
less runtime/log/202509.log
# 实时监控新增日志(tail -f)
tail -f runtime/log/202509.log
# 搜索ERROR日志
grep 'ERROR' runtime/log/202509.log
php think log命令快速查看所有日志文件内容:php think log # 查看所有日志
php think log -l error # 仅查看ERROR级别日志
syslog),可使用journalctl查看:journalctl -u apache2 | grep 'ThinkPHP' # 查看Apache关联的ThinkPHP日志
journalctl --since "2025-09-01" --until "2025-09-30" # 按时间筛选
rm -rf runtime/log/*.log # 删除所有.log文件
logrotate工具定期压缩、删除旧日志,避免磁盘空间耗尽。
/etc/logrotate.d/下新建thinkphp文件:sudo nano /etc/logrotate.d/thinkphp
/path/to/your/project/runtime/log/*.log {
daily # 每天轮转
rotate 7 # 保留7天
missingok # 文件不存在不报错
notifempty # 空文件不轮转
compress # 压缩旧日志(.gz)
delaycompress # 延迟压缩(避免当天日志被压缩)
sharedscripts # 所有日志处理完再执行脚本
postrotate
/usr/bin/php /path/to/your/project/think log:clear # 可选:执行ThinkPHP日志清理命令
endscript
}
sudo logrotate -vf /etc/logrotate.d/thinkphp # 手动测试
logrotate会自动通过cron每天运行(无需额外配置)。runtime/log/目录需属于Web服务器用户(如www-data),避免权限不足导致日志无法写入:chown -R www-data:www-data runtime/log/
chmod -R 755 runtime/log/
Log::record的context参数过滤:Log::error('登录失败', ['username' => $username, 'ip' => $ip]); // 不记录密码
DEBUG级别,防止日志文件过大。通过以上步骤,可实现ThinkPHP在Ubuntu环境中的高效日志管理,覆盖配置、记录、查看、清理全流程,确保应用运行状态可追溯。