laravel mysql 队列_Laravel 队列使用

Laravel 队列使用

1.修改根目录

.env文件的 **QUEUE_CONNECTION **字段配置为 database

Laravel可配置多种队列驱动,包括 "sync", "database", "beanstalkd", "sqs", "redis", "null"(具体参见app/config/queue.php)

其中sync为同步,database为使用数据库,后面三种为第三方队列服务,最后一种为不使用队列。

f45d55fee18487afde9e51fc0ce92b8a.png

该位置具体是什么请查看app/queue

a00f9fd1805c60eb456f7b92f79d3aac.png

2.创建数据库队列表(database方式)

为了使用 database 队列驱动,你需要一张数据表来存储任务。

php artisan queue:table

生产一张队列表

php artisan migrate

mysql版本5.7.7以下可能会报如下错误

b0c750546f42950cd4ae9e7b6ef36bd4.png

解决方案

打开app/Providers/AppServiceProvider文件,在boot方法中加入如下代码,删除数据库中已经生成的迁移数据表,再次运行就可以成功。

一定要删除已经生成的job数据表,否者汇报如下错误

3187b2c7d947a9023a9d9fa999c186ff.png

\Schema::defaultStringLength(191); //add fixed sql

数据库最终效果

4c691dbac3e3241fb5715bb6542652b9.png

3.生成任务类

在你的应用程序中,队列的任务类都默认放在 app/Jobs 目录下。

如果这个目录不存在,那当你运行 make:job Artisan 命令时目录就会被自动创建。

你可以用以下的 Artisan 命令来生成一个新的队列任务:

php artisan make:job SetLog

500d03d7af8959d026c6227822413738.png

4.在队列类里面的handle方法中写上业务逻辑(比如发送网络请求,发送邮件等等,这里简单写个日志代替)

protected $message;

/**

* Create a new job instance.

*

* @return void

*/

public function __construct($message)

{

$this->message = $message;

}

/**

* Execute the job.

*

* @return void

*/

public function handle()

{

\Log::info($this->message);

}

5.在控制器中加入一个测试方法,直接调用队列类的 dispatch方法,类似生产了一个任务

public function index(Request $request){

SetLog::dispatch(date('Y-m-d H:i:s') . "进入了系统");

}

这时,由于队列还没开启,数据库的队列表中会有一个任务,等待队列启动后执行

7fb783aabc5898df21314a3d360ee44d.png

6.执行命令开启队列

php artisan queue:work

这时,队列表中的任务执行后就会自动删除了,类似消费了任务

f54769812a6279036c399e570b98798e.png

97cc29d7f4da9530153c97e56f226b04.png

bf3482cf91a2c2c09fa8a238660a0b10.png

以上是抛转引玉的一个简单例子,具体细节可以查看laravel的队列文档

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值