Laravel 5 task scheduling with cron job example

Laravel 5 task scheduling with cron job example

Laravel 5 task scheduling with cron job example

If you want to execute scheduling jobs in specific time and specific interval then you can apply cron job which is a Unix command.

We can manage a task in the server that executes scripts which helps in sending daily/weekly reports from our website.

The main use of cron job is in cleaningup the databases, sending the emails, executing the time consuming tasks etc. We can simply delete files from the database with the help of Cron Job.

Cron job will only work on unix based machines. It consists of a configuration file called Crontable which is also known as Crontab.

This Cron tab is used to manage the scheduling and consists of different cron jobs and each of the cron job is associated with a specific task.

Generate A New Command Class :

First, we will generate our own custom commands by running following commands which will generate a class in the app/Console/Commands/ directory.

php artisan make:console CustomCommand

After running this command you will get a message 'Console command created successfully. ' on your terminal and then it generate a class file at app/Console/Commands/CustomCommand.php with default signature but you can assign the terminal command name by using --command option.

php artisan make:console CustomCommand --command=custom:command

Whenever command will be executed in your terminal then handle method of command class is called so i will write a code to delete all inactive users in handle method.

  1. namespace App\Console\Commands;
  2. use Illuminate\Console\Command;
  3. use DB;
  4. class CustomCommand extends Command
  5. {
  6. /**
  7. * The name and signature of the console command.
  8. *
  9. * @var string
  10. */
  11. protected $signature = 'custom:command';
  12. /**
  13. * The console command description.
  14. *
  15. * @var string
  16. */
  17. protected $description = 'Delete all inactive users';
  18. /**
  19. * Create a new command instance.
  20. *
  21. * @return void
  22. */
  23. public function __construct()
  24. {
  25. parent::__construct();
  26. }
  27. /**
  28. * Execute the console command.
  29. *
  30. * @return mixed
  31. */
  32. public function handle()
  33. {
  34. DB::table('users')->where('active', 0)->delete();
  35. $this->info('All inactive users are deleted successfully!');
  36. }
  37. }

Now we have to register our new command with Artisan so that it will be available in terminal. For this we just need to add this command class name to commands array in Kernerl class that is available in app/Console/Kernel.php.

app/Console/Kernel.php
  1. namespace App\Console;
  2. use Illuminate\Console\Scheduling\Schedule;
  3. use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
  4. class Kernel extends ConsoleKernel
  5. {
  6. /**
  7. * The Artisan commands provided by your application.
  8. *
  9. * @var array
  10. */
  11. protected $commands = [
  12. Commands\CustomCommand::class,
  13. ];
  14. /**
  15. * Define the application's command schedule.
  16. *
  17. * @param \Illuminate\Console\Scheduling\Schedule $schedule
  18. * @return void
  19. */
  20. protected function schedule(Schedule $schedule)
  21. {
  22. $schedule->command('custom:command')->daily();
  23. }
  24. }

If you want to see your command description in terminal then run following command :

$ php artisan list
  1. custom
  2. custom:command Delete all inactive users

Now you can run your command to delete all inactive users.

$ php artisan custom:command

All inactive users are deleted successfully!

As you notice i schedule the command on daily basis but there are number of schedule frequencies which you can assign to the tasks.

Schedule tasks hourly basis

  1. $schedule->command('custom:command')
  2. ->hourly();

Schedule tasks on given time

  1. $schedule->command('custom:command')
  2. ->dailyAt('07:00');

Schedule tasks weekly basis

  1. $schedule->command('custom:command')
  2. ->weekly();

Schedule tasks monthly basis

  1. $schedule->command('custom:command')
  2. ->monthly();

If you wan to start the scheduler itself then you will have to add one cron job on server using the crontab -e command.

* * * * * php /path/to/artisan schedule:run >> /dev/null 2>&1

Using this, Laravel command scheduler will be called by cron every minute.

Phone: (+91) 8800417876
Noida, 201301