0

0

laravel怎么监听数据库查询事件_laravel数据库查询事件监听方法

穿越時空

穿越時空

发布时间:2025-11-09 09:11:02

|

190人浏览过

|

来源于php中文网

原创

可通过事件系统监听 Laravel 数据库查询,首先使用 DB::listen 在 AppServiceProvider 中捕获所有 SQL 执行信息并写入日志文件,为保持结构清晰可创建独立的 DatabaseQueryServiceProvider 并注册到配置中,生产环境应添加执行时间条件(如超过 100ms)以减少日志量,同时推荐结合 Laravel Telescope 实现可视化监控,通过安装包、发布资源及迁移后访问 /telescope 查看详细查询数据。

laravel怎么监听数据库查询事件_laravel数据库查询事件监听方法

如果您在开发 Laravel 应用时需要追踪数据库查询行为,例如记录慢查询、调试 SQL 执行或监控特定模型的查询操作,可以通过事件系统来捕获数据库查询的执行过程。以下是实现数据库查询事件监听的具体方法。

本文运行环境:MacBook Pro,macOS Sonoma

一、使用 DB::listen 监听所有查询

该方法可以全局监听应用程序中所有执行的 SQL 查询语句,适用于调试和性能分析。通过注册一个监听器,可以在每次查询执行后获取 SQL、绑定参数和执行时间。

1、打开 AppServiceProvider.php 文件,在 boot 方法中添加 DB::listen 回调。

2、引入 DB 门面:use Illuminate\Support\Facades\DB;

3、在 boot 方法内添加如下代码块:

DB::listen(function ($query) {
   file_put_contents(storage_path('logs/sql.log'),
      "Time: {$query->time}ms | SQL: {$query->sql} | Bindings: ".json_encode($query->bindings)."\n",
   FILE_APPEND);
});

4、确保 storage/logs/ 目录存在且可写,否则日志将无法生成。

二、基于事件服务提供者分离监听逻辑

为了保持代码结构清晰,建议将数据库查询监听逻辑独立到专门的服务提供者中,避免 AppServiceProvider 过于臃肿。

1、使用 Artisan 命令创建新的服务提供者:php artisan make:provider DatabaseQueryServiceProvider

2、在新创建的 DatabaseQueryServiceProvider.php 中,于 boot 方法内编写与 DB::listen 相同的监听逻辑。

3、将该服务提供者注册到 config/app.php 的 providers 数组中:'providers' => [... App\Providers\DatabaseQueryServiceProvider::class]

4、重新加载配置缓存:php artisan config:clear,使注册生效。

三、条件性记录查询以减少日志量

在生产环境中直接记录所有查询会导致日志文件迅速膨胀,因此可通过设置阈值仅记录执行时间较长的查询。

1、修改 listen 回调中的判断逻辑,加入执行时间过滤条件。

2、示例代码如下:

DB::listen(function ($query) {
   if ($query->time > 100) { // 仅记录超过100毫秒的查询
      file_put_contents(storage_path('logs/slow_queries.log'),
         "Slow Query ({$query->time}ms): {$query->sql} | ".json_encode($query->bindings)."\n",
         FILE_APPEND);
   }
});

3、根据实际性能需求调整时间阈值,如 50ms 或 200ms。

四、结合 Laravel Telescope 进行可视化监控

Laravel Telescope 是官方提供的调试工具,能自动收集数据库查询信息,并提供 Web 界面查看,适合开发阶段使用。

1、通过 Composer 安装 Telescope:composer require laravel/telescope

2、发布资源文件并执行迁移:php artisan telescope:install && php artisan migrate

3、访问 /telescope 路径即可查看实时数据库查询列表,包括 SQL、执行时间、调用堆等详细信息。

4、可在 config/telescope.php 中配置数据保留策略和过滤规则。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

1725

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1148

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1051

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

948

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1396

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1228

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1439

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

虚拟号码教程汇总
虚拟号码教程汇总

本专题整合了虚拟号码接收验证码相关教程,阅读下面的文章了解更多详细操作。

25

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Laravel---API接口
Laravel---API接口

共7课时 | 0.6万人学习

PHP自制框架
PHP自制框架

共8课时 | 0.6万人学习

PHP面向对象基础课程(更新中)
PHP面向对象基础课程(更新中)

共12课时 | 0.6万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号