Laravel-任务调度

举报
lxw1844912514 发表于 2022/03/27 02:56:10 2022/03/27
【摘要】 简介Cron 是 UNIX、SOLARIS、LINUX 下的一个十分有用的工具,通过 Cron 脚本能使计划任务定期地在系统后台自动运行。这种计划任务在 UNIX、SOLARIS、LINUX下术语为 Cron Jobs。Crontab 则是用来记录在特定时间运行的 Cron 的一个脚本文件,Crontab 文件的每一行均遵守特定的...

简介
Cron 是 UNIX、SOLARIS、LINUX 下的一个十分有用的工具,通过 Cron 脚本能使计划任务定期地在系统后台自动运行。这种计划任务在 UNIX、SOLARIS、LINUX下术语为 Cron Jobs。Crontab 则是用来记录在特定时间运行的 Cron 的一个脚本文件,Crontab 文件的每一行均遵守特定的格式:


我们可以在服务器上通过 crontab -e 来新增或编辑 Cron 条目,通过 crontab -l 查看已存在的 Cron 条目。更多关于 Cron 的原理和使用细节请自行百度或 Google。

在以前,开发者需要为每一个需要调度的任务编写一个 Cron 条目,这是很让人头疼的事。你的任务调度不在源码控制中,你必须使用 SSH 登录到服务器然后添加这些 Cron 条目。

Laravel 命令调度器允许你流式而又不失优雅地在 Laravel 中定义命令调度,并且服务器上只需要一个 Cron 条目即可。任务调度定义在 app/Console/Kernel.php 文件的 schedule 方法中,该方法中已经包含了一个示例。

开启调度器
下面是你唯一需要添加到服务器的 Cron 条目,如果你不知道如何添加 Cron 条目到服务器,可以考虑使用诸如 Laravel Forge 这样的服务来为管理 Cron 条目:

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

该 Cron 将会每分钟调用一次 Laravel 命令调度器,当 schedule:run 命令执行后,Laravel 评估你的调度任务并运行到期的任务。

1 添加Cron到服务器


    
  1. crontab -e 进入编辑模式 添加下面的内容:
  2. * * * * * /usr/local/php/bin/php /home/wwwroot/web.laravel.cn/artisan schedule:run >> /dev/null 2>&1
  3. * * * * * 时间
  4. /usr/local/php/bin/php : 你自己php的环境 [whereis php]
  5. /home/wwwroot/web.laravel.cn/artisan : artsian目录
  6. schedule:run >> /dev/null 2>&1 : 固定写法

2 创建文件

php artisan make:console LogInfo [自定义文件名] 如果报错则运行 php artisan make:command =======================================================================================================================
  

在以前, 开发者需要为每一个需要调度的任务编写一个 Cron 条目, 这是很让人头疼的事. 你的任务调度不在源码控制中, 你必须使用 SSH 登录到服务器然后添加这些 Cron 条目. Laravel 命令调度器允许你平滑而又富有表现力地在 Laravel 中定义命令调度, 并且服务器上只需要一个 Cron 条目即可, 任务调度又是我们俗称的 “计划任务”

任务调度定义在 app/Console/Kernel.php 文件的 schedule 方法中, 该方法中已经包含了一个示例. 你可以自由地添加你需要的调度任务到Schedule 对象

开启调度


    
  1. // 在 linux 环境中执行
  2. * * * * * root php /var/www/laravel/artisan schedule:run

/var/www/laravel 为你的项目目录, 该 Cron 将会每分钟调用 Laravel 命令调度, 然后 Laravel 评估你的调度任务并运行到期的任务.

定义调度
在 项目根目录 下创建定时任务所需要进行的操作

创建命令
php artisan make:console Stat_Test 该操作会在 app/Console/Commands 下生成一个 Stat_Test.php, 以下是小例子


    
  1. <?php
  2. namespace App\Console\Commands;
  3. use Illuminate\Console\Command;
  4. class Stat_Test extends Command
  5. {
  6. /**
  7. * The name and signature of the console command.
  8. *
  9. * @var string
  10. */
  11. protected $signature = 'stat:test';
  12. /**
  13. * The console command description.
  14. *
  15. * @var string
  16. */
  17. protected $description = 'stat:test';
  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. $this->addData();
  35. }
  36. // 例子
  37. public function addData() {
  38. $time = time();
  39. $rand = rand(1, 1000);
  40. $id = \DB::table('data_test')->insertGetId(['uuid' => $time, 'uuid' => $rand]);
  41. if ($id) {
  42. \Log::info('定时/数据插入成功', $id);
  43. } else {
  44. \Log::error('定时/数据插入失败', $time);
  45. }
  46. }
  47. }


值得注意的是 这个文件中的 $signature = 'stat:test' 这个签名在 Kernel.php 中也要相应用到, 下面是附上 Kernel.php 的完整代码


    
  1. <?php
  2. namespace App\Console;
  3. use Illuminate\Console\Scheduling\Schedule;
  4. use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
  5. class Kernel extends ConsoleKernel
  6. {
  7. /**
  8. * The Artisan commands provided by your application.
  9. *
  10. * @var array
  11. */
  12. protected $commands = [
  13. \App\Console\Commands\Inspire::class,
  14. '\App\Console\Commands\Stat_Test',
  15. ];
  16. /**
  17. * Define the application's command schedule.
  18. *
  19. * @param \Illuminate\Console\Scheduling\Schedule $schedule
  20. * @return void
  21. */
  22. protected function schedule(Schedule $schedule)
  23. {
  24. // 为测试方便 每分钟执行一次
  25. $schedule->command('stat:test')->everyMinute();
  26. }
  27. }

再强调一次 $schedule->command('stat:test') 里面的 stat:test 必须和上面的签名 $signature = 'stat:test' 对应上

引入调度文件


    
  1. protected $commands = [
  2. \App\Console\Commands\Inspire::class,
  3. '\App\Console\Commands\Stat_Test',
  4. ];

 


    
  1. // 每周星期六 11:00 运行一次...
  2. $schedule->command('stat:test')->weekly()->saturdays()->at('11:00');
  3. // 每周星期一 01:00 运行一次...
  4. $schedule->command('stat:test')->weekly()->->mondays()->at('01:00');


调度常用选项
当然,你可以分配多种调度到任务


    
  1. ->cron('* * * * *'); 在自定义 Cron 调度上运行任务
  2. ->everyMinute(); 每分钟运行一次任务
  3. ->everyFiveMinutes(); 每五分钟运行一次任务
  4. ->everyTenMinutes(); 每十分钟运行一次任务
  5. ->everyThirtyMinutes(); 每三十分钟运行一次任务
  6. ->hourly(); 每小时运行一次任务
  7. ->daily(); 每天凌晨零点运行任务
  8. ->dailyAt('13:00'); 每天 13:00运行任务
  9. ->twiceDaily(1, 13); 每天 1:00 & 13:00 运行任务
  10. ->weekly(); 每周运行一次任务
  11. ->monthly(); 每月运行一次任务

下面是额外的调度约束列表


    
  1. ->weekdays(); 只在工作日运行任务
  2. ->sundays(); 每个星期天运行任务
  3. ->mondays(); 每个星期一运行任务
  4. ->tuesdays(); 每个星期二运行任务
  5. ->wednesdays(); 每个星期三运行任务
  6. ->thursdays(); 每个星期四运行任务
  7. ->fridays(); 每个星期五运行任务
  8. ->saturdays(); 每个星期六运行任务
  9. ->when(Closure); 基于特定测试运行任务

  

 

 
  

文章来源: blog.csdn.net,作者:lxw1844912514,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/lxw1844912514/article/details/100028679

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。