How to Create Custom Log File in Laravel 8 Tutorial

Share this Article
Reading Time: 4 minutes
513 Views

Inside this article we will see how to create custom log file in laravel 8. We can easily track errors on files after looking into log file. Log files are those files in which application status like errors, information, warnings, etc stored. Log files help application developer to debug applications.

This tutorial will help you to log custom application status into custom log file for your laravel application. You can store any log type messages like of errors, warnings, etc.

Laravel by default provide /storage/logs/laravel.log file location where it stores application logs. But sometime we may need to create log file with specific task. For example, if someone works with payment task and need all logs at a fixed place, so this article will help you.

Also for maintaining logs we have a composer package which exactly do the same thing what we are discussing. Click here to learn about LogViewer package and it’s working.

Learn More –

Let’s get started.


Installation of Laravel Application

Laravel Installation can be done in two ways.

  • Laravel Installer
  • By using composer

Laravel Installer

To install Laravel via Laravel installer, we need to install it’s installer first. We need to make use of composer for that.

$ composer global require laravel/installer

This command will install laravel installer at system. This installation is at global scope, so you type command from any directory at terminal. To verify type the given command –

$ laravel

This command will open a command palette of Laravel Installer.

To create ad install laravel project in system,

$ laravel new blog

With the name of blog a laravel project will be created at your specified path.

By using composer

Alternatively, we can also install Laravel by Composer command create-project.

If your system doesn’t has composer Installed, Learn Composer Installation Steps.

Here is the complete command to create a laravel project-

$ composer create-project --prefer-dist laravel/laravel blog

After following these steps we can install a Laravel application into system.

To start the development server of Laravel –

$ php artisan serve

This command outputs –

Starting Laravel development server: http://127.0.0.1:8000

Assuming laravel already installed at system.


Add Custom Log Settings

Open logging.php file from /config folder.

Inside logging.php search for channels.

Inside channels array, add your settings for custom log.

'channels' => [

       ...       

       'webtutorlog' => [
            'driver' => 'single',
            'path' => storage_path('logs/applicationlog.log'),
            'level' => 'info',
        ],

],

webtutorlog is channel name. applicationlog.log is custom log file name where we will store our custom log messages.

storage_path(‘logs/applicationlog.log’) It returns path as /storage/logs/applicationlog.log


Create Test Logs

Open web.php from /routes folder. Add this route into it.

//...

Route::get('create-log', function () {
  
    \Log::channel('webtutorlog')->info('This is info log level for testing');
    \Log::channel('webtutorlog')->warning('This is warning log level for testing');
    \Log::channel('webtutorlog')->error('This is error log level for testing');
    \Log::channel('webtutorlog')->alert('This is alert log level for testing');
    \Log::channel('webtutorlog')->emergency('This is emergency log level for testing');
    \Log::channel('webtutorlog')->notice('This is notice log level for testing');
    
    dd('done');
     
});

//...

Application Testing

Open project to terminal and type the command to start development server

$ php artisan serve

URL – http://127.0.0.1:8000/create-log

You will get applicationlog.log file inside /storage/logs folder. When you open, you should see these lines added into it.

[2021-09-18 13:19:19] local.INFO: This is info log level for testing  
[2021-09-18 13:19:19] local.WARNING: This is warning log level for testing  
[2021-09-18 13:19:19] local.ERROR: This is error log level for testing  
[2021-09-18 13:19:19] local.ALERT: This is alert log level for testing  
[2021-09-18 13:19:19] local.EMERGENCY: This is emergency log level for testing  
[2021-09-18 13:19:19] local.NOTICE: This is notice log level for testing  

We hope this article helped you to learn How to Create Custom Log File in Laravel 8 Tutorial in a very detailed way.

Buy Me a Coffee

If you liked this article, then please subscribe to our YouTube Channel for PHP & it’s framework, WordPress, Node Js video tutorials. You can also find us on Twitter and Facebook.

Find More on Laravel 8 Articles here