Maison  >  Article  >  développement back-end  >  Laravel modifie le nom et l'emplacement du fichier journal par défaut

Laravel modifie le nom et l'emplacement du fichier journal par défaut

不言
不言original
2018-07-05 14:42:531973parcourir

Cet article explique principalement comment modifier le nom et l'emplacement du fichier journal par défaut dans Laravel. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer

Modifier le journal par défaut. location

Dans notre développement habituel, nous pouvons toujours placer les fichiers journaux de Laravel dans l'emplacement par défaut sans aucun impact, mais si notre projet est entièrement déployé lors de sa mise en ligne et que chaque déploiement est le dernier code dans git, alors à ce moment-là, nos journaux seront effacés à chaque fois, montrant que ce n'est pas ce à quoi nous nous attendions. Heureusement, laravel nous fournit un moyen de le modifier.

Ici, nous prenons /var/log/nginx/app/phphub/phphub.log comme exemple

Ajouter une classe de traitement des journaux#

Nous créons d'abord un nouveau fichier, app /Foundation/Bootstrap/ConfigureLogging.php, le code est le suivant :

<?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 = &#39;configure&#39;.ucfirst($app[&#39;config&#39;][&#39;app.log&#39;]).&#39;Handler&#39;;
 $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(&#39;config&#39;);
 $filename = $config->get(&#39;app.log_path&#39;, &#39;/var/log/nginx/app/system&#39;) . &#39;/&#39; . $config->get(&#39;app.log_name&#39;, &#39;laravel&#39;) . &#39;.log&#39;;
 $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(&#39;config&#39;);
 $filename = $config->get(&#39;app.log_path&#39;, &#39;/var/log/nginx/app/system&#39;) . &#39;/&#39; . $config->get(&#39;app.log_name&#39;, &#39;laravel&#39;) . &#39;.log&#39;;
 $log->useDailyFiles(
 $filename,
 $app->make(&#39;config&#39;)->get(&#39;app.log_max_files&#39;, 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(&#39;config&#39;)->get(&#39;app.log_name&#39;, &#39;laravel&#39;));
 }
 /**
 * 设置应用errorlog模式下的Monolog处理程序
 *
 * @param \Illuminate\Contracts\Foundation\Application $app
 * @param \Illuminate\Log\Writer $log
 * @return void
 */
 protected function configureErrorlogHandler(Application $app, Writer $log)
 {
 $log->useErrorLog();
 }
}

Configurer le chemin de stockage des journaux #

Ajouter

APP_NAME=phphub

dans .env Ajoutez

/**
 * 应用程序名称
 */
&#39;name&#39; => env(&#39;APP_NAME&#39;, &#39;laravel&#39;),
/**
 * 日志位置
 */
&#39;log_path&#39; => &#39;/var/log/nginx/app/&#39; . env(&#39;APP_NAME&#39;, &#39;laravel&#39;),
/**
 * 日志文件名称
 */
&#39;log_name&#39; => env(&#39;APP_NAME&#39;, &#39;laravel&#39;),
/**
 * 日志文件最大数
 */
&#39;log_max_files&#39; => &#39;30&#39;,

à config/app.php et appliquez notre nouvelle classe de traitement #

Modifiez Bootstrap/app.php et ajoutez le code

$app->configureMonologUsing(function($monolog) use ($app) {
 $configureLogging = new App\Foundation\Bootstrap\ConfigureLogging();
 $configureLogging->configureHandlers($app, $app->log);
});
Pour le moment, nous pouvons utiliser

pour le tester, et le journal doit être enregistré dans Log::info('test log info');. /var/log/nginx/app/phphub/phphub.log

Ce qui précède représente l'intégralité du contenu de cet article. J'espère qu'il sera utile à l'étude de chacun. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois !

Recommandations associées :

Comment afficher les journaux dans le terminal Laravel

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn