幽灵资源网 Design By www.bzswh.com
修改 bootstrap/app.php 文件
$app->configureMonologUsing(function($monolog) use ($app) { $monolog->pushHandler( (new Monolog\Handler\RotatingFileHandler( '/var/logs/app/laravel', $app->make('config')->get('app.log_max_files', 5) ))->setFormatter(new Monolog\Formatter\LineFormatter(null, null, true, true)) ); });
添加以后写入日志文件为:
-rw-r--r-- 1 web web 93 Dec 18 15:52 laravel-2017-12-17 -rw-r--r-- 1 web web 279 Dec 18 16:10 laravel-2017-12-18
参考:Laravel 的错误和日志记录
或者
创建app\Providers\LogServiceProvider.php 文件
修改 config\app.php providers 增加
App\Providers\LogServiceProvider::class
然后 App\Providers\LogServiceProvider.php 内容如下
<"htmlcode">namespace App\Providers; use Illuminate\Support\ServiceProvider; use Carbon\Carbon; class LogServiceProvider extends ServiceProvider { protected $log_file; /** * Bootstrap any application services. * @return void */ public function boot() { // } /** * Register any application services. * @return void */ public function register() { $this->load_request_id(); $this->log_configure(); } /** * 生成 request_id * @return void */ protected function load_request_id() { define( 'REQUEST_ID' , config('app.log_prefix').Carbon::now()->timestamp ); } /** * 注册 monolog pushHandler * @return void */ protected function log_configure() { $log_file = $this->getLogFile(); $log_max_files = $this->getLogMaxFiles(); /** * @doc https://d.laravel-china.org/docs/5.4/errors#自定义-Monolog-设置 */ $this->app->configureMonologUsing(function($monolog) use ($log_file , $log_max_files) { $monolog->pushHandler( (new \Monolog\Handler\RotatingFileHandler( $log_file , $log_max_files ))->setFormatter(new \Monolog\Formatter\LineFormatter( "[%datetime%] [".REQUEST_ID."] %channel%.%level_name%: %message% %context% %extra%\n", null, true, true)) ); }); } protected function getLogMaxFiles() { return config('app.log_max_files' , 5); } /** * @return mixed */ protected function getLogFile() { if( is_null( $this->log_file) ) { $this->log_file = rtrim(config('app.log_path') , DIRECTORY_SEPARATOR )."/laravel.log"; } return $this->log_file; } }优化以后
namespace App\Providers; use Illuminate\Support\ServiceProvider; use Monolog\Formatter\LineFormatter; use Monolog\Handler\RotatingFileHandler; use Carbon\Carbon; use Monolog\Logger;; use ReflectionClass; class LogServiceProvider extends ServiceProvider { protected $log_file; /** * Bootstrap any application services. * * @return void */ public function boot() { // } /** * Register any application services. * * @return void */ public function register() { $this->loadRequestId(); /** * 根据日期来分割日志 */ $this->useDailyFiles(); } protected function loadRequestId() { define( 'REQUEST_ID' , config('app.log_prefix').Carbon::now()->timestamp ); } /** * 根据日期来分割日志 */ protected function useDailyFiles() { $handler = $this->getDailyHandler()->setFormatter( $this->getDefaultFormatter() ); $errorHandler = $this->getDailyHandler(Logger::ERROR)->setFormatter( $this->getDefaultFormatter() ); $this->app->configureMonologUsing( function( $monolog) use ( $handler , $errorHandler ) { $monolog->pushHandler( $handler ); $monolog->pushHandler( $errorHandler ); }); } /** * 设置 日志 行格式 * @return LineFormatter */ protected function getDefaultFormatter() { $format = "[%datetime%] [".REQUEST_ID."] %channel%.%level_name%: %message% %context% %extra%\n"; return new LineFormatter( $format , null, true, true); } /** * 根据日志区分 * @return \Monolog\Handler\RotatingFileHandler */ protected function getDailyHandler( $level = Logger::DEBUG) { return new RotatingFileHandler( $this->logPath().$this->logName( $level ) , $this->maxFiles() , $level ); } /** * 日志文件最多个数 * @return int */ protected function maxFiles() { if ($this->app->bound('config')) { return $this->app->make('config')->get('app.log_max_files', 30); } return 0; } /** * 日志文件名称 * @return mixed */ protected function logPath() { $logPath = $this->app->storagePath()."/logs/"; if( $this->app->bound('config')) { $logPath = $this->app->make('config')->get('app.log_path', $logPath ); } return $logPath; } /** * log 完整文件名 * @param int $level * @return string */ protected function logName( $level = Logger::DEBUG ) { return $this->getAppName().'-'.$this->getLevelName( $level ).".log"; } /** * 获取项目app * @return mixed */ protected function getAppName() { return $this->app->make('config')->get('app.name'); } /** * 获取log错误级别名称 * @param $level * @return mixed */ protected function getLevelName( $level ) { $r = new ReflectionClass( Logger::class ); $constants = array_flip( $r->getConstants() ); return $constants[$level]; } }以上这篇自定义Laravel (monolog)日志位置,并增加请求ID的实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。