En esta página:
Laravel el potente Framework PHP nos da la posibilidad de Programar Tareas en nuestro Servidor, estas tareas se ejecutarán incluso cuando no estés pendiente de tu servidor, nos ayuda a resolver múltiples tareas y a facilitarnos la vida, veamos como programar una tarea en nuestro servidor así veremos lo sencillo y rápido que es hacerlo con Laravel. Usaremos la versión 5.6 de Laravel.
Lo que haremos es que el servidor ejecute un comando que elimina los datos de nuestra tabla postres, este comando le indicaremos que se ejecute 1 ves por minuto.
Cron en Servidor
Ve al administrador de tu servidor y crea un nuevo Comando en el Cron y agrega el siguiente comando
1 2 3 |
* * * * * php /ruta-de-tu-proyecto/artisan schedule:run >> /dev/null 2>&1 |
Con ello le decimos que ejecute se ejecute el comando a cada minuto o una sola ves por minuto
Tabla Postres de la DB
En nuestro servidor tenemos una tabla llamada postres con los siguientes datos, los cuales desparecerán al ejecutar el comando que crearemos a continuación
Task Scheduling
Las tareas las debemos especificar en el archivo Kernel.php lo podemos encontrar en la carpeta app > Console > Kernel.php dentro del conjunto de archivos de Laravel.
En el archivo Kernel.php instanciamos el Trait DB para decirle a Laravel que usaremos la Base de datos
1 2 3 |
use DB; |
Luego en la función schedule usamos el método call para decirle que borre los datos de la tabla postres a cada minuto con el método everyMinute();
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
/** * Define the application's command schedule. * * @param \Illuminate\Console\Scheduling\Schedule $schedule * @return void */ protected function schedule(Schedule $schedule) { $schedule->call(function () { DB::table('postres')->delete(); })->everyMinute(); } |
El código completo del archivo Kernel.php quedaría así:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 |
<?php namespace App\Console; use DB; use Illuminate\Console\Scheduling\Schedule; use Illuminate\Foundation\Console\Kernel as ConsoleKernel; class Kernel extends ConsoleKernel { /** * The Artisan commands provided by your application. * * @var array */ protected $commands = [ //Commands\ComandoPersonalizado::class ]; /** * Define the application's command schedule. * * @param \Illuminate\Console\Scheduling\Schedule $schedule * @return void */ protected function schedule(Schedule $schedule) { $schedule->call(function () { DB::table('postres')->delete(); })->everyMinute(); } /** * Register the Closure based commands for the application. * * @return void */ protected function commands() { require base_path('routes/console.php'); } } |
Tras esperar un minuto que se ejecuta el comando, revisamos nuestra tabla postres y los datos han sido borrados
Síguenos en nuestras Redes Sociales para que no te pierdas nuestros próximos contenidos.