Laravel怎样修改默认日志名及位置
Admin 2022-05-20 群英技术资讯 487 次浏览
修改默认日志位置
我们平常的开发中可能一直把laravel的日志文件放在默认位置不会有什么影响,但如果我们的项目上线时是全量部署,每次部署都是git中最新的代码,那这个时候每次都会清空我们的日志,显示这不是我们所期望的,好在laravel有提供我们修改的方法。
我们这里以放在/var/log/nginx/app/phphub/phphub.log为例
增加日志处理类#
首先我们新建文件,app/Foundation/Bootstrap/ConfigureLogging.php,代码如下:
<?php namespace App\Foundation\Bootstrap; use Illuminate\Log\Writer; use Illuminate\Contracts\Foundation\Application; class ConfigureLogging { /** * 设置应用的Monolog处理程序 * * @param \Illuminate\Contracts\Foundation\Application $app * @param \Illuminate\Log\Writer $log * @return void */ public function configureHandlers(Application $app, Writer $log) { $method = 'configure'.ucfirst($app['config']['app.log']).'Handler'; $this->{$method}($app, $log); } /** * 设置应用single模式下的Monolog处理程序 * * @param \Illuminate\Contracts\Foundation\Application $app * @param \Illuminate\Log\Writer $log * @return void */ protected function configureSingleHandler(Application $app, Writer $log) { $config = $app->make('config'); $filename = $config->get('app.log_path', '/var/log/nginx/app/system') . '/' . $config->get('app.log_name', 'laravel') . '.log'; $log->useFiles($filename); } /** * 设置应用daily模式下的Monolog处理程序 * * @param \Illuminate\Contracts\Foundation\Application $app * @param \Illuminate\Log\Writer $log * @return void */ protected function configureDailyHandler(Application $app, Writer $log) { $config = $app->make('config'); $filename = $config->get('app.log_path', '/var/log/nginx/app/system') . '/' . $config->get('app.log_name', 'laravel') . '.log'; $log->useDailyFiles( $filename, $app->make('config')->get('app.log_max_files', 5) ); } /** * 设置应用syslog模式下的Monolog处理程序 * * @param \Illuminate\Contracts\Foundation\Application $app * @param \Illuminate\Log\Writer $log * @return void */ protected function configureSyslogHandler(Application $app, Writer $log) { $log->useSyslog($app->make('config')->get('app.log_name', 'laravel')); } /** * 设置应用errorlog模式下的Monolog处理程序 * * @param \Illuminate\Contracts\Foundation\Application $app * @param \Illuminate\Log\Writer $log * @return void */ protected function configureErrorlogHandler(Application $app, Writer $log) { $log->useErrorLog(); } }
配置日志存放路径#
在.env中增加
APP_NAME=phphub
在config/app.php中增加
/** * 应用程序名称 */ 'name' => env('APP_NAME', 'laravel'), /** * 日志位置 */ 'log_path' => '/var/log/nginx/app/' . env('APP_NAME', 'laravel'), /** * 日志文件名称 */ 'log_name' => env('APP_NAME', 'laravel'), /** * 日志文件最大数 */ 'log_max_files' => '30',
应用我们新的处理类#
修改Bootstrap/app.php,在return $app前增加代码
$app->configureMonologUsing(function($monolog) use ($app) { $configureLogging = new App\Foundation\Bootstrap\ConfigureLogging(); $configureLogging->configureHandlers($app, $app->log); });
这时候我们可以使用\Log::info('test log info');测试一下,应该就会将日志记录在/var/log/nginx/app/phphub/phphub.log中了。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
php中的标量数据类型总结 PHP 的数据类型可以分为三大类,分别是标量数据类型.复合数据类型和特殊数据类型. 其中,标量数据类型是数据结构的最基础单元,只能存储一个数据.在 PHP 中的标量数据类型分为四种,如下表所示: 类型 功能 boolean(布尔型) 最简单的数据类型,只有两个值:true(真) / false(假) string(字符串) 字符串是连续的字符序列 integer(整型) 整型包含所有的整数,可以是正数也可以是负数 float(浮点型) 浮点型也是用来表示数字的,与整型不同除了可以表示整数外它还可
概述我们都知道HTTP是一种协议,允许WEB服务器和浏览器通过互联网进行发送和接受数据。想对HTTP进行详细的了解,可以找下其他文章,这篇文章不多做介绍。我们在网上能看到的界面,图片,动画,音频,视频等,都有依赖这个协议的。在做WEB系统的时候,都使用过IIS,Apache,Nginx吧,我们利用Swoole也可以简单的实现一个WEB服务器。主要使用了HTTP的两个大对象:Request请求对象,Response响应对象。请求,包括GET,POST,COOK
本文主要介绍了php实现ffmpeg处理视频的实践,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
方法:1、将“.env”文件中的“APP_DEBUG”项内容修改为false;2、将Laravel服务重新启动即可。“.env”文件中的“APP_DEBUG”设置为false时,表示关闭debug模式,true就表示开启debug模式。
php数组合并的方法:1、array_merge数字key被归为0,包含相同的key,则保留第二个key值;2、array_merge_recursive数字key为0,包含相同key时,合成数组;3、array_combine创建新数组。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008