Laravel日志系统基于Monolog构建,支持文件、数据库、Slack等多种渠道。通过config/logging.php配置通道,如single、daily、slack等,默认使用stack驱动聚合多个通道。可在.env中设置LOG_CHANNEL指定默认通道。可自定义通道如payment,按天分割日志并保留14天,写入特定文件。支持添加Monolog处理器和格式化器,如设置级别为warning,自定义日志格式。还可运行时动态创建日志实例,用于临时任务。系统灵活,便于问题排查。

Laravel 的日志系统基于强大的 Monolog 库构建,提供了灵活的日志记录方式。你可以轻松将日志写入文件、标准输出、数据库、Slack、Telegram 等多种渠道。Laravel 通过配置驱动来管理不同的日志“通道”,让你能根据环境和需求选择合适的方式记录错误、调试信息或关键事件。
默认日志配置
Laravel 的日志配置文件位于 config/logging.php。该文件定义了多个日志通道(channels),每个通道代表一种日志输出方式。默认情况下,Laravel 使用 stack 驱动作为主通道,它可以聚合多个日志通道。
常见内置驱动包括:
- single:单个日志文件(storage/logs/laravel.log)
- daily:按天分割日志文件,最多保留几天
- slack:发送日志到 Slack 频道
- syslog:写入系统日志
- errorlog:使用 PHP 的 error_log 函数
- stderr:输出到标准错误流
stack。
自定义日志通道
你可以在 config/logging.php 中的 channels 数组里添加自定义通道。例如,创建一个专门记录支付相关日志的 daily 类型通道:
'payment' => [
'driver' => 'daily',
'path' => storage_path('logs/payment.log'),
'level' => 'debug',
'days' => 14,
],
登录后复制
然后在代码中使用这个通道:
\Log::channel('payment')->info('订单支付成功', ['order_id' => 12345]);
登录后复制
这会将信息写入 storage/logs/payment-2025-04-05.log(按日期命名)。
使用 Monolog 自定义处理器和格式化器
Laravel 允许你在通道中注册 Monolog 的处理器(Handler)和格式化器(Formatter),实现更精细控制。
标签: 日志记录 laravel php 处理器 ai stream 配置文件 2025
还木有评论哦,快来抢沙发吧~