The Laravel web framework comes with a lot of powerful tools and one of them it the Task Scheduler. This allows you to create and manage all your automated – Cron Jobs – tasks within the framework. If you do not write Cron jobs often, going through documentation or memorizing the Crontab syntax and expression can be extra work (I usually use crontab.guru to simplify this ). Laravel uses functions such as everyTwoMinutes()
which is simple to remember and implement. There is also per second scheduling which is not available by default on crontab.
First, you have to open the app/Console/Kernel.php
file. Your scheduled task will be added in the schedule(Schedule $schedule)
function, by calling the $schedule
object. There four main types of calls you can make using the $schedule
object:
- A closure function containing Laravel/PHP code you wish to run.
- A command which runs an Artisan command.
- A queued Job.
- Command line scripts which can run external scripts.
I will be running an external script (using exec
) to get my systems stats and then send them to myself every 5 minutes. To use an already setup docker environment you can clone this repo and follow the setup instructions (If you choose to use the docker environment. Run your commands in the ‘web’ container) . Copy the code block below in the schedule function:
$command = 'echo "------------------" >> out.txt &&';
$command .= 'top -b -n 1 >> out.txt &&';
$command .= 'echo "------------------" >> out.txt &&';
$command .= 'cat /proc/meminfo >> out.txt &&';
$command .= 'echo "------------------"';
$schedule->exec($command)
->appendOutputTo('out.txt')
->name('System Stats')
->everyFiveMinutes()
->emailOutputTo('me@example.com');
Then first test using php artisan schedule:test
select the number associated with this task and click enter. if there are no errors, run php artisan schedule:work
to start the scheduler if you are on a development environment. For production, add this to your Crontab :
* * * * * cd /path-to-your-project && php artisan schedule:run >> /dev/null 2>&1
NOTE:
- Ensure email sender (mailer) of choice is configured on the .env file.
- If you choose to use the docker environment. Run your commands in the ‘web’ container.
That’s it, you can include other server stats you want to send through email in the exec
function of the scheduler.
References:
- Laravel Documentation: https://laravel.com/docs/10.x/scheduling#task-output
Leave a Reply