Laravel给生产环境添加监听事件(SQL日志监听)
本文主要给大家介绍的是关于Laravel给生产环境添加监听事件(SQL日志监听)的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:
laravel版本:5.2.*
一、创建监听器
phpartisanmake:listenerQueryListener--event=Illuminate\\Database\\Events\\QueryExecuted
or
sudo/usr/local/bin/phpartisanmake:listenerQueryListener--event=Illuminate\\Database\\Events\\QueryExecuted
会自动生成文件app/Listeners/QueryListener.php
二、注册事件
打开app/Providers/EventServiceProvider.php,在$listen中添加Illuminate\Database\Events\QueryExecuted事件的监听器为QueryListener
protected$listen=[ 'Illuminate\Database\Events\QueryExecuted'=>[ 'App\Listeners\QueryListener', ], ];
最终代码如下
namespaceApp\Providers; useIlluminate\Contracts\Events\DispatcherasDispatcherContract; useIlluminate\Foundation\Support\Providers\EventServiceProviderasServiceProvider; classEventServiceProviderextendsServiceProvider { /** *Theeventlistenermappingsfortheapplication. * *@vararray */ protected$listen=[ 'App\Events\SomeEvent'=>[ 'App\Listeners\EventListener', ], 'Illuminate\Database\Events\QueryExecuted'=>[ 'App\Listeners\QueryListener', ], ]; /** *Registeranyothereventsforyourapplication. * *@param\Illuminate\Contracts\Events\Dispatcher$events *@returnvoid */ publicfunctionboot(DispatcherContract$events) { parent::boot($events); // } }
三、添加逻辑
打开app/Listeners/QueryListener.php
光有一个空的监听器是不够的,我们需要自己实现如何把$sql记录到日志中。为此,对QueryListener进行改造,完善其handle方法如下:
$sql=str_replace("?","'%s'",$event->sql); $log=vsprintf($sql,$event->bindings); Log::info($log);
最终代码如下
namespaceApp\Listeners; useLog; useIlluminate\Database\Events\QueryExecuted; useIlluminate\Queue\InteractsWithQueue; useIlluminate\Contracts\Queue\ShouldQueue; classQueryListener { /** *Createtheeventlistener. * *@returnvoid */ publicfunction__construct() { // } /** *Handletheevent. * *@paramQueryExecuted$event *@returnvoid */ publicfunctionhandle(QueryExecuted$event) { $sql=str_replace("?","'%s'",$event->sql); $log=vsprintf($sql,$event->bindings); Log::info($log); } }
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。