修改默认日志位置

我们平常的开发中可能一直把laravel的日志文件放在默认位置不会有什么影响,但如果我们的项目上线时是全量部署,每次部署都是git中最新的代码,那这个时候每次都会清空我们的日志,显示这不是我们所期望的,好在laravel有提供我们修改的方法。

我们这里以放在/var/log/nginx/app/phphub/phphub.log为例

增加日志处理类#

首先我们新建文件,app/Foundation/Bootstrap/ConfigureLogging.php,代码如下:

  1. <?php
  2.  
  3. namespace App\Foundation\Bootstrap;
  4.  
  5. use Illuminate\Log\Writer;
  6. use Illuminate\Contracts\Foundation\Application;
  7.  
  8. class ConfigureLogging
  9. {
  10.  
  11. /**
  12. * 设置应用的Monolog处理程序
  13. *
  14. * @param \Illuminate\Contracts\Foundation\Application $app
  15. * @param \Illuminate\Log\Writer $log
  16. * @return void
  17. */
  18. public function configureHandlers(Application $app, Writer $log)
  19. {
  20. $method = 'configure'.ucfirst($app['config']['app.log']).'Handler';
  21.  
  22. $this->{$method}($app, $log);
  23. }
  24.  
  25. /**
  26. * 设置应用single模式下的Monolog处理程序
  27. *
  28. * @param \Illuminate\Contracts\Foundation\Application $app
  29. * @param \Illuminate\Log\Writer $log
  30. * @return void
  31. */
  32. protected function configureSingleHandler(Application $app, Writer $log)
  33. {
  34. $config = $app->make('config');
  35. $filename = $config->get('app.log_path', '/var/log/nginx/app/system') . '/' . $config->get('app.log_name', 'laravel') . '.log';
  36. $log->useFiles($filename);
  37. }
  38.  
  39. /**
  40. * 设置应用daily模式下的Monolog处理程序
  41. *
  42. * @param \Illuminate\Contracts\Foundation\Application $app
  43. * @param \Illuminate\Log\Writer $log
  44. * @return void
  45. */
  46. protected function configureDailyHandler(Application $app, Writer $log)
  47. {
  48. $config = $app->make('config');
  49. $filename = $config->get('app.log_path', '/var/log/nginx/app/system') . '/' . $config->get('app.log_name', 'laravel') . '.log';
  50. $log->useDailyFiles(
  51. $filename,
  52. $app->make('config')->get('app.log_max_files', 5)
  53. );
  54. }
  55.  
  56. /**
  57. * 设置应用syslog模式下的Monolog处理程序
  58. *
  59. * @param \Illuminate\Contracts\Foundation\Application $app
  60. * @param \Illuminate\Log\Writer $log
  61. * @return void
  62. */
  63. protected function configureSyslogHandler(Application $app, Writer $log)
  64. {
  65. $log->useSyslog($app->make('config')->get('app.log_name', 'laravel'));
  66. }
  67.  
  68. /**
  69. * 设置应用errorlog模式下的Monolog处理程序
  70. *
  71. * @param \Illuminate\Contracts\Foundation\Application $app
  72. * @param \Illuminate\Log\Writer $log
  73. * @return void
  74. */
  75. protected function configureErrorlogHandler(Application $app, Writer $log)
  76. {
  77. $log->useErrorLog();
  78. }
  79. }

配置日志存放路径#

在.env中增加

APP_NAME=phphub

在config/app.php中增加

  1. /**
  2. * 应用程序名称
  3. */
  4. 'name' => env('APP_NAME', 'laravel'),
  5.  
  6. /**
  7. * 日志位置
  8. */
  9. 'log_path' => '/var/log/nginx/app/' . env('APP_NAME', 'laravel'),
  10.  
  11. /**
  12. * 日志文件名称
  13. */
  14. 'log_name' => env('APP_NAME', 'laravel'),
  15.  
  16. /**
  17. * 日志文件最大数
  18. */
  19. 'log_max_files' => '30',

应用我们新的处理类#

修改Bootstrap/app.php,在return $app前增加代码

  1. $app->configureMonologUsing(function($monolog) use ($app) {
  2. $configureLogging = new App\Foundation\Bootstrap\ConfigureLogging();
  3. $configureLogging->configureHandlers($app, $app->log);
  4. });

这时候我们可以使用\Log::info('test log info');测试一下,应该就会将日志记录在/var/log/nginx/app/phphub/phphub.log中了。

Laravel 修改默认日志文件名称和位置的更多相关文章

  1. springmvc基础篇—修改默认的配置文件名称及位置

    springmvc的默认配置文件是放在WEB-INF下的,叫action-servlet.xml.根据咱们编程的习惯,一般都将配置文件放到src的根目录下,那么如何将这个文件迁移过来呢?其实很简单,请 ...

  2. C# 插件热插拔 .NET:何时应该 “包装异常”? log4.net 自定义日志文件名称

    C# 插件热插拔   所谓热插拔就是插件可以 在主程序不重新启动的情况直接更新插件, 网上有很多方案: https://www.cnblogs.com/happyframework/p/3405811 ...

  3. WAL日志文件名称格式详解

    转自:http://blog.osdba.net/534.html WAL日志文件名称格式详解 PostgreSQL的WAL日志文件在pg_xlog目录下,一般情况下,每个文件为16M大小: osdb ...

  4. log4j配置文件动态指定日志文件名称

    我们在项目当中经常会使用log4j进行日志记录,偶尔会遇到一些要求,比如日志文件名称按照启动参数动态配置,而不去修改log4j.xml,比较简单的一种做法是,通过设置系统属性的方式实现,代码: if( ...

  5. 动态指定log4net日志文件名称

    如果是希望日志文件按常见的日期格式动态命名,没什么好说的,直接修改app.config <param name="DatePattern" value="yyyyM ...

  6. log4j2配置文件动态指定日志文件名称

    按照习惯性思维,log4j2中xml中取系统属性应该和log4j一样,但是结果却并不是我们想的这样,存在一定的差别,log4j中的配置可参考 log4j配置文件动态指定日志文件名称 . 现在就来看看到 ...

  7. Confluence 6 修改日志文件的目标位置

    在 log4j 中,一个输出被定义为 'appender'.希望修改 log 文件的目标,你需要停止 Confluence 然后修改设置 log4j.properties 日志配置文件的  'Logg ...

  8. rabbitmq更换数据文件和日志文件的存放位置

    原来的默认位置是/var下 需要将这些文件更换位置 1.先创建数据文件和日志文件存放位置的目录并给权限 mkdir -p /usr/local/rabbitmq/mnesia mkdir -p /us ...

  9. [PHP] - Laravel - 修改laravel_session的cookie名称

    修改Cookie laravel_session的名称方法: 打开文件:config\session.php 找到值:laravel_session 修改为你所需要的cookie名称即可. 当然,还有 ...

随机推荐

  1. LUGOU 3959 宝藏 (noip 2017 day2 T2)

    传送门 解题思路 去年noip现在拿来写..思路还是听清楚的,记忆化搜索,f[S]表示现在选了集合S时的最小代价,dis[i]表示达到最优时i这个点的深度.f[S| (1< < i-1) ...

  2. QT应用qmake添加应用图标

    总体解决方案: 1.搜索 [Setting the Application Icon]帮助 2.http://doc.qt.io/qt-5/appicon.html 3.可以在主pro文件中加入如下语 ...

  3. BP神经网络分类应用

    DNA序列分类  作为研究DNA序列结构的尝试,提出以下对序列集合进行分类的问题:有20个已知类别的人工制造序列,其中序列标号1-10为A类,11-20为B类.请从中提取特征,构造分类方法,并用这些已 ...

  4. css中background背景属性概述

    background:url(背景图片路径) no-repeat;/*不重复默认在左上方*/ background:url(背景图片路径) no-repeat center;/*不重复背景图片中间显示 ...

  5. vue中 表头 th 合并单元格,且表格列数不定的动态渲染方法

    吐槽 今天,在vue中遇到 复杂表格的渲染 ,需要合并表头th的单元格,且合并单元格的那列的表头数据是动态数据,也就是不知道会有多少个表头列,而这几个表头列还分了好几个子表头. 这个需求在js里用Ju ...

  6. Jmeter压测报错:Non HTTP response code: java.net.ConnectExceptionexception的解决办法

    前一段时间进行jmeter压测时,一直报错,查看了下日志才发现报了一堆Non HTTP response code: java.net.ConnectExceptionexception,直接jmet ...

  7. 【CF Manthan, Codefest 17 B】Marvolo Gaunt's Ring

    [链接]h在这里写链接 [题意] 给你n个数字; 让你在其中找出三个数字i,j,k(i<=j<=k); 使得p*a[i]+q*a[j]+r*a[k]最大; [题解] /*     有一个要 ...

  8. JavaScript--对象继承(组合继承)

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 大数据技术之Oozie

      第1章 Oozie简介 Oozie英文翻译为:驯象人.一个基于工作流引擎的开源框架,由Cloudera公司贡献给Apache,提供对Hadoop MapReduce.Pig Jobs的任务调度与协 ...

  10. 外贸电子商务网站之Prestashop 语言包安装

    prestashop添加语言-下载语言包 我们找到中文简体(Chinese-Simplified)一行,点击最后一栏的下载(Download)按钮,我们点击下载,可以下到一个以语言的 ISO为文件名, ...