2021年5月20日16:59:38
环境windows laravel8 mysql8 redis
官方文档:https://learnku.com/docs/laravel/8.x/queues/9398
laravel实现异步任务,其实就是利用队列服务来对队列添加任务,来实现异步操作,也是一个不错的实现异步的办法
修改配置
QUEUE_CONNECTION=redis
生成任务类
php artisan make:job Test
Test代码
<?php
namespace App\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldBeUnique;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
use mysql_xdevapi\Exception;
class Test implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct($orderData)
{
//
p($orderData);
p('zx');
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
// sleep(5);
p(111111111111);
// throw new Exception('11');
}
}
生成队列失败监控数据库
php artisan queue:table
php artisan queue:failed-table
php artisan migrate
生成的文件在 database\migrations
这里有个问题在
AppServiceProvider 文件里面添加
<?php
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use Illuminate\Support\Facades\Schema;
class AppServiceProvider extends ServiceProvider
{
/**
* Register any application services.
*
* @return void
*/
public function register()
{
//
}
/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
//
Schema::defaultStringLength(191);
}
}
监听队列
php artisan queue:listen
开启队列
php artisan queue:work --queue=default --tries=2
开启多个
php artisan queue:work --queue=default,mytask --tries=2
如何生成失败信息
public function handle()
{
throw new Exception('11');
}
只要扔出异常就会生成失败记录
查看失败任务:
php artisan queue:failed
丢一个任务到队列中
<?php
namespace App\Http\Controllers\Open\V1;
use Illuminate\Http\Request;
use App\Models\Tesco\UUser;
use App\Jobs\Test;
class IndexOpenController extends BaseController
{
public function test(Request $request)
{
$orderData = 2222222222;
dispatch_now(new Test($orderData));//立即异步执行方法
dispatch(new Test($orderData))->delay(10);
}
}
如果需要在线上使用就使用supervisor
广播系统其实更简单一点,就是同过socket服务,加上redis做channel来投递信息
其实借用rebitmq来做广播系统会更好