Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道

发布时间 - 2025-12-19 00:00:00    点击率:
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:输出到标准错误流
在 .env 文件中可通过 LOG_CHANNEL 设置当前使用的通道,默认为 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),实现更精细控制。

例如,添加一个只记录警告及以上级别的处理器,并自定义输出格式:

'custom_file' => [
    'driver' => 'monolog',
    'handler' => \Monolog\Handler\StreamHandler::class,
    'with' => [
        'stream' => storage_path('logs/custom.log'),
    ],
    'level' => 'warning',
    'formatter' => \Monolog\Formatter\LineFormatter::class,
    'formatter_with' => [
        'format' => "[%datetime%] %level_name%: %message% %context% %extra%\n",
        'date_format' => 'Y-m-d H:i:s',
    ],
],

这样配置后,只有 warning、error 等级别日志会被写入,且格式清晰统一。

运行时动态写入不同日志

除了预定义通道,你也可以在代码中动态创建日志实例:

$logger = new \Monolog\Logger('runtime');
$logger->pushHandler(new \Monolog\Handler\StreamHandler(storage_path('logs/runtime.log'), \Monolog\Logger::INFO));

$logger->info('运行时日志', ['data' => 'example']);

适用于临时任务或特殊模块的日志隔离。

基本上就这些。Laravel 日志系统足够灵活,既能满足日常开发需求,也能通过 Monolog 扩展支持复杂场景。合理使用多通道和级别控制,能让日志更清晰、便于排查问题。


# laravel  # php  # 处理器  # ai  # stream  # 配置文件  # 2025  # Error  # Logging  # 事件  # 数据库  # 自定义  # 多个  # 你可以  # 等多种  # 最多  # 几天  # 你在  # 也能  # 适用于  # 可在 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: canvas 画布在主流浏览器中的尺寸限制详细介绍  Laravel如何创建和注册中间件_Laravel中间件编写与应用流程  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  Swift开发中switch语句值绑定模式  Laravel如何编写单元测试和功能测试?(PHPUnit示例)  详解Android——蓝牙技术 带你实现终端间数据传输  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作  Laravel怎么使用artisan命令缓存配置和视图  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】  Bootstrap整体框架之CSS12栅格系统  Laravel如何实现本地化和多语言支持?(i18n教程)  Laravel Session怎么存储_Laravel Session驱动配置详解  网站制作价目表怎么做,珍爱网婚介费用多少?  Python正则表达式进阶教程_复杂匹配与分组替换解析  googleplay官方入口在哪里_Google Play官方商店快速入口指南  悟空识字如何进行跟读录音_悟空识字开启麦克风权限与录音  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  如何做网站制作流程,*游戏网站怎么搭建?  如何确保FTP站点访问权限与数据传输安全?  Laravel如何处理JSON字段的查询和更新_Laravel JSON列操作与查询技巧  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  Win11怎么设置默认图片查看器_Windows11照片应用关联设置  如何确保西部建站助手FTP传输的安全性?  Win11怎么查看显卡温度 Win11任务管理器查看GPU温度【技巧】  浅析上传头像示例及其注意事项  Laravel观察者模式如何使用_Laravel Model Observer配置  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  如何在阿里云香港服务器快速搭建网站?  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  如何在建站之星网店版论坛获取技术支持?  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南  如何获取PHP WAP自助建站系统源码?  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  千库网官网入口推荐 千库网设计创意平台入口  Laravel如何记录自定义日志?(Log频道配置)  如何在万网自助建站中设置域名及备案?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  Laravel distinct去重查询_Laravel Eloquent去重方法  ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集  移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?  Laravel如何使用Collections进行数据处理?(实用方法示例)  如何正确选择百度移动适配建站域名?  js实现点击每个li节点,都弹出其文本值及修改