laravel日志配置在config/logging.php中,通过修改channels数组中的level选项设置日志级别(如debug、info、error等),并选择single、daily、stack等driver指定存储方式,例如daily可设置days保留天数;2. symfony日志配置位于config/packages/monolog.yaml,通过handlers定义处理方式,设置level控制日志级别,并使用stream、console等handler指定输出路径或方式,支持参数如%kernel.logs_dir%动态生成路径;3. codeigniter 4日志配置在app/config/logger.php中,通过threshold数值控制记录级别(0为全部,1为error及以上),handlers数组配置处理类如filehandler并指定path存储路径;4. 自定义日志格式方面,laravel和symfony可在配置中设置formatter选项,codeigniter 4需继承lineformatter创建自定义格式化器;5. 代码中使用日志时,laravel用log::info(),symfony通过loggerinterface注入使用$info(),codeigniter 4调用log_message()函数;6. 配置不同日志级别可区分事件严重性,便于生产环境过滤无关信息;7. 不同环境日志配置可通过laravel的.env文件、symfony的环境化配置文件、codeigniter 4的环境专属logger.php实现;8. 日志轮转方面,laravel的daily驱动自动按天轮转并保留指定天数,symfony可使用rotatingfilehandler配置策略,codeigniter 4默认不支持需手动或借助第三方库实现。正确配置日志能显著提升应用调试与维护效率,确保问题可追溯。

PHP框架日志配置,简单来说,就是告诉框架,哪些错误或信息需要记录,以及记录到哪里。这直接影响到你调试和维护应用的效率。
配置日志级别和存储方式,实际上就是告诉你的PHP框架,什么等级的信息需要记录,以及把这些信息放到哪里。不同的框架,实现方式略有差异,但核心思路是相通的。
配置不同框架的日志,让问题无处遁形
立即学习“PHP免费学习笔记(深入)”;
Laravel的日志配置藏在
config/logging.php
channels
配置日志级别: 在
channels
stack
single
daily
level
level
debug
info
notice
warning
error
critical
alert
emergency
warning
level
warning
配置存储方式: 同样在
channels
single
daily
days
stack
syslog
errorlog
error_log
举个例子,如果你想使用
daily
'channels' => [
'daily' => [
'driver' => 'daily',
'path' => storage_path('logs/laravel.log'),
'level' => env('LOG_LEVEL', 'debug'),
'days' => 7,
],
],别忘了在
.env
LOG_LEVEL
LOG_LEVEL=debug
Symfony的日志配置在
config/packages/monolog.yaml
配置handlers: 在
monolog.yaml
handlers
channels
配置日志级别: 在每个handler中,可以设置
level
debug
info
notice
warning
error
critical
alert
emergency
配置存储方式: Symfony的handler种类非常多,可以灵活地配置存储方式。
stream
path
console
syslog
firephp
例如,你想把
error
var/log/prod.log
monolog:
handlers:
main:
type: stream
path: "%kernel.logs_dir%/%kernel.environment%.log"
level: error
channels: ["!event"]这里的
%kernel.logs_dir%
%kernel.environment%
CodeIgniter 4的日志配置在
app/Config/Logger.php
配置threshold:
threshold
error
error
debug
配置handlers:
handlers
配置存储方式: 默认情况下,CodeIgniter 4会将日志写入
writable/logs
handlers
例如,你想记录所有级别的日志,并将它们写入文件,可以这样配置:
public $threshold = 0; // 0表示记录所有日志
public $handlers = [
'CodeIgniter\Logs\Handlers\FileHandler' => [
'handles' => ['critical', 'alert', 'error', 'warning', 'notice', 'info', 'debug', 'emergency'],
'path' => WRITEPATH . 'logs/',
],
];除了配置日志级别和存储方式,自定义日志格式也很重要。不同的框架提供了不同的方式来实现。
config/logging.php
formatter
monolog.yaml
formatter
CodeIgniter\Logs\Formatters\LineFormatter
Logger.php
配置好日志之后,就可以在代码中使用了。
Log
Log::info('User logged in', ['user_id' => $user->id]);Psr\Log\LoggerInterface
$this->logger->info('User logged in', ['user_id' => $user->id]);log_message()
log_message('info', 'User logged in', ['user_id' => $user->id]);注意,日志信息应该包含足够的信息,方便定位问题。可以包含用户ID、请求参数、时间戳等等。
不同的日志级别对应着不同严重程度的事件。
debug
info
notice
warning
error
critical
alert
emergency
通过配置不同的日志级别,可以让你在生产环境中只关注重要的错误信息,避免被大量的调试信息淹没。
通常,开发环境和生产环境需要不同的日志配置。
.env
LOG_LEVEL
monolog.yaml
kernel.environment
app/Config/
app/Config/Development/Logger.php
app/Config/Production/Logger.php
长时间运行的程序会产生大量的日志,如果不进行轮转,日志文件会变得非常大,影响性能。
daily
days
RotatingFileHandler
FileHandler
日志轮转的策略有很多种,可以按天、按大小、按时间等等。选择合适的策略,可以有效地管理日志文件。
以上就是PHP框架如何配置日志级别与存储方式 PHP框架日志配置的操作教程的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号