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
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 = '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(); } }
Ajouter
APP_NAME=phphub
dans .env Ajoutez
/** * 应用程序名称 */ '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',
Modifiez Bootstrap/app.php et ajoutez le code
< avant de renvoyer $ app 🎜>$app->configureMonologUsing(function($monolog) use ($app) { $configureLogging = new App\Foundation\Bootstrap\ConfigureLogging(); $configureLogging->configureHandlers($app, $app->log); });
pour le tester, et le journal doit être enregistré dans Log::info('test log info');
. /var/log/nginx/app/phphub/phphub.log
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!