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中了。

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM