task schedule php,基于Laravel Task-Scheduler定时发送邮件小程序

说明:本文主要学习Laravel的Artisan Command、Task Scheduler和Mail相关知识。做一个简单的小demo,用来定时发邮件。。走完整个流程最多只需一小时。同时,作者会将开发过程中的一些截图和代码黏上去,提高阅读效率。

作者的开发环境是本机的MAMP集成软件,PHP7.0,Laravel5.2.*。

Laravel中Artisan Command内容可以参看:服务 —— Artisan Console,Mail邮件服务内容可以参看:服务 —— 邮件,以及Task-Scheduler任务定时器可以参看:服务 —— 任务调度。

Artisan Command

新建一个artisan command:

php artisan make:console SendEmails --command=emails:send

并在AppConsoleCommandsSendEmails.php文件中添加代码:

class SendEmails extends Command

{

/**

* The name and signature of the console command.

*

* @var string

*/

protected $signature = 'emails:send';

/**

* The console command description.

*

* @var string

*/

protected $description = 'This is a demo about sending emails to myself';

/**

* Create a new command instance.

*

* @return void

*/

public function __construct()

{

parent::__construct();

}

/**

* Execute the console command.

*

* @return mixed

*/

public function handle()

{

$this->info('I am handsome');

$this->error('I am not ugly');

}

}

写上$description和handle()方法,$description变量用来显示命令的说明,handle()用来处理命令,然后在AppConsoleCommandsKernel.php中注册命令:

protected $commands = [

// Commands\Inspire::class,

Commands\SendEmails::class,

];

好,这下可以在终端输入php artisan查看并执行命令了:

bVvn1c?w=1206&h=222

bVvn1d?w=1006&h=130

Mail

邮件服务API驱动需要安装guzzlehttp/guzzle这个包,在项目根目录下:

composer require guzzlehttp/guzzle

然后在.env文件中配置下邮件驱动和用户名密码:

bVvn4r?w=570&h=232

然后修改下handle()方法:

/**

* Execute the console command.

*

* @return mixed

*/

public function handle()

{

// $this->info('I am handsome');

// $this->error('I am not ugly');

$user = [

'email' => 'XXX@XXX.com',//一个有效的邮箱接收地址

'name' => 'liuxiang',

];

$status = Mail::send('emails.send', ['user'=>$user], function($msg) use ($user){

$msg->from('XXX@XXX.com', 'liuxiang email');//一个有效的邮箱发送地址

$msg->to($user['email'], $user['name'])->subject('This is a demo about sending emails to myself');

});

if(!$status){

$this->error('Fail to send email');exit;

}

$this->info('Success to send email');exit;

}

发送的内容在视图emails.send里,新建resources/views/emails/send.blade.php文件:

Bootstrap Template

html,body{

width: 100%;

height: 100%;

}

*{

margin: 0;

border: 0;

}

.content{

text-align: center;

margin: 50px;

}

This is a email by Laravel Artisan Command

一切准备OK,在项目根目录运行邮件发送命令吧,然后会收到邮件发送成功打印:

bVvn54?w=1016&h=70

然后接收的邮箱会收到邮件:

bVvn6e?w=1364&h=326

It is working!!!

Task-Scheduler

每次手动发邮件毕竟不太爽啊,可以利用系统的定时器crontab定时发送,Laravel里有任务定时器可以玩一玩。修改app/Console/Kernel.php文件:

/**

* Define the application's command schedule.

*

* @param \Illuminate\Console\Scheduling\Schedule $schedule

* @return void

*/

protected function schedule(Schedule $schedule)

{

// $schedule->command('inspire')->hourly();

//$schedule->command('emails:send')->everyFiveMinutes();

$schedule->command('emails:send')->everyMinutes();

}

在终端输入crontab -e 添加一个cron条目:

* * * * * php /Applications/MAMP/htdocs/laravelemail/artisan schedule:run 1>> /dev/null 2>&1

然后程序每隔一分钟发个邮件过来:

bVvn92?w=866&h=932

总结:本文主要以Laravel的Artisan Command、Mail和Task-Scheduler做一个好玩的小demo,来定时发发骚扰邮件,哈哈。还挺好玩的,可以试一试。。嘛,过几天想结合设计模式来聊聊Laravel,到时见。

taskPHP taskPHP基于php开发的定时计划任务框架,利用多进程实现任务的分配和运行,利用内存共享实现进程间通信,支持多线程模式需要安装pthreads扩展(可选),支持linux和windows。有较好的伸缩性、扩展性、健壮稳定性而被多家公司使用,同时也希望开源爱好者一起贡献。   框架概况 框架目录结构: taskPHP 根目录 |-- core 框架系统目录 | |-- lib 框架核心文件目录 | | |-- .... 众多的框架核心类库文件 | |-- guide.php 框架引导文件 | |-- distribute_listen.php 任务派发进程入口 | |-- worker_listen.php 任务执行进程入口 |-- docs 开发文档存放目录 |-- logs 日志目录 |-- tasks 用户任务目录 | |-- demo demo任务 | | |-- Lib demo任务的扩展目录 | | |-- demoTask.php demo任务类文件 | | |-- config.php demo任务配置文件 | | ... 更多任务 | |-- config.php 全局配置文件 |-- main.php 框架入口文件 |-- windows_single.cmd windows快速启动文件 框架说明 linux下子进程执行任务,修改脚本无需重启后台服务立即生效,windows下修改任务脚本后需重启后台脚本 但往系统添加执行不受影响。 框架支持多线程模式,需要安装pthreads扩展(可选)。 使用内存共享实现进程通信,堵塞式消息队列,整个框架的运行无需第三方扩展。 任务派发及具体任务执行不在同个进程[distribute_listen.php]和[worker_listen.php],windows和linux下启用入口文件[main.php],windows下可运行[windows_single.cmd]快速启动。 执行时间语法跟crontab类似,且支持秒设置。 添加任务简单,只需继承Task基类,实现任务入口run方法。 环境要求 php版本>= 5.5 开启shmop 注意事项 由于任务存在派发时间,所以任务运行的时间可能会有1-2秒的误差。 windows下执行任务在循环里,编写任务有问题或调用exit将导致后台脚本停止,linux下无此问题。 建议生产部署在linux下运行多进程模式,因为运行在多线程模式运行一段时间后报错,pthreads has detected that the core\lib\Pthread could not be started, the system lacks the necessary resources or the system-imposed limit would be exceeded in xxx 文档列表 -->数据库类使用教程 支持(Mysql,Mongo,Oracle,Pgsql,Sqlsrv,Sqllite) -->windows下安装php多线程扩展pthreads教程 -->工具类Utils使用说明 -->http请求客户端类Client使用说明 使用说明 时间配置格式说明: * * * * * * * //格式 :秒 分 时 天 月 年 周 10 * * * * * * //表示每一分钟的第10秒运行 /10 * * * * * * //表示每10秒运行 /1 * 15,16 * * * * //表示 每天的15点,16点的每一秒运行 系统命令说明: main.php [start] 启动 可不带参数 main.php close 结束 main.php reload 重新加载任务 main.php delete demo 删除任务 main.php select 查看任务列表 main.php exec demo 运行任务 主要用于任务开发中调试单个任务 全局配置文件规范 标签:taskphp  计划任务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值