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:输出到标准错误流
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节点,都弹出其文本值及修改

