时间:2021-05-26
修改默认日志位置
我们平常的开发中可能一直把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中了。
以上这篇Laravel 修改默认日志文件名称和位置的例子就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了PHP批量修改文件名称的方法。分享给大家供大家参考,具体如下:在这里我们利用一个战地自己写的一个例子来具体分析一下利用PHP批量修改文件名称的思路
1,修改文件名。Windows修改文件夹、文件名称的快捷键是F2,那么MAC对应的快捷键是什么呢?靠想一定想不到。修改文件名称快捷键:Enter2,在终端,方向
上传文件路径、文件名可知。要知道脚本文件上传到服务器后其所存放路径及文件名称,因为许多Web应用都会修改上传文件的文件名称,那么这时就需要结合其他漏洞去获取到这
本文实例讲述了Java实现批量修改txt文件名称的方法。分享给大家供大家参考,具体如下:最近在做特征选择的实验时,需要批量修改一下文件名称,在这里做一下记录。p
复制代码代码如下://////导出word文件//////模板路径///导出文件名称///pdf文件名称///模板内书签集合///发票条目列表publicsta