zoukankan      html  css  js  c++  java
  • Laravel 修改默认日志文件名称和位置

    修改默认日志位置

    我们平常的开发中可能一直把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中了。

     

  • 相关阅读:
    把文本文件数据快速导入Sql Server
    db4o, 看上去很美
    从《黑暗森林》事件谈下我对网络时代正版,盗版的看法
    viewDidUnload 和 dealloc 的区别(转)
    (翻译)cocoaasyncsocket 异步Socket
    iPhone的Socket编程使用开源代码之AsyncSocket(转)
    iphone之开源类库工具
    ObjectC 中各数据类型转换 NSData转NSString,Byte,UIImage
    iphone开发ObjectiveC新特性──类别与协议(转)
    让WebForm异步起来(转)
  • 原文地址:https://www.cnblogs.com/lxwphp/p/15454203.html
Copyright © 2011-2022 走看看