laravel使用队列的简单步骤

2018-08-28 10:00:24

最近需要导入大量的excel文件,数量达到十万之多。

而我又不想修改服务器的超时时间,因为这样可能影响服务器的堵塞。


而php又没有很好的异步。


后来发现了令laravel最为骄傲的部分,队列。具体文档参考下方链接。


laravel队列介绍


简单操作如下:

Laravel5提供了完善的队列功能,只需要简单的配置即可使用。这里简单记录下关于异步队列的用法。 配置 关于队列的定义,这里就不作介绍了。我们要使用异步队列就有两个关键:

     1.存储队列的地方

     2.执行任务的服务 。

打开 config/queue.php,这是Laravel5关于队列的配置文件。首先我们可以通过 default参数指定默认队列驱动,默认配置是 sync, 这是同步队列,我们要做异步队列首先就要改变这里。

假设我们用 database作为驱动,队列任务将会存放在数据库中,而我们后面会另外启动一个后台服务来处理队列任务,这就是异步方式了。 'default' => 'database' 修改完配置后,我们需要创建一个表来存放队列任务,Laravel5已经在自带artisan命令中内置了一个指令用来生成数据迁移,只需要两条命令即可,当然你得实现配置好数据库连接。

 php artisan queue:table  php artisan migrate 这样就自动在数据库中创建了 jobs 表。 


启动队列监听服务 通过下面这条指令启动队列监听服务,它会自动处理 jobs 表中的队列任务: php artisan queue:work

在linux中,如果想让它在后台执行,可以这样: nohup php artisan queue:listen & 添加队列任务 关于队列任务的添加,手册里说的比较详细,这里就简单举个例子吧。 首先,通过artisan创建一个队列命令: php artisan make:command SendEmail --queued 这样会生成 app/Commands/SendEmail.php这个类文件,这个类会被标识为队列命令,你可以在 handle方法中写自己的业务逻辑。 在控制器中,可以简单通过 Bus::dispatch分发任务: Bus::dispatch(new /App/Commands/SendEmail()); 你会发现任务不会立即执行,而是被放到 jobs 表中,由队列监听服务处理。 更详细的用法建议参考 command bus 和 queue 相关的手册章节。 


因为 php artisan queue:work 不是守候进程,我们采用

再linux我们采用supervisor 来进行我们的守候进程。具体supervisor的配置,我laravel队列supervisor的配置参考下一篇文章。

  • 2019-12-20 13:27:16

    腾讯地图谷歌和高德地图等自定义地图区别

    腾讯、百度、Google的地图投影均采用Web Mercator 投影坐标系;腾讯与Google的地图瓦片分辨率及切片范围是完全相同的,仅仅是命名规则稍有不同,这就使得同一位置和缩放级别的地图瓦片是完全可以重叠的;而百度地图每个缩放级别分辨率与前两者均不相同,而且地图瓦片的坐标原点做了一定的偏移,导致百度地图与前两者的瓦片是无法重叠的,这是因为百度在GCJ-02的基础上又进行了加密处理,形成了百度独有的BD-09坐标系。

  • 2019-12-22 08:06:48

    如何快速撤销上一次的commit

    在平时工作中使用git难免会提交一些错误的文件到git库里,这时候,撤销吧,怕把正确的文件删除了,不撤销重新改又很麻烦,下面,我就从提交的三个阶段,来讲解如何撤销错误的操作。

  • 2019-12-23 14:54:03

    RPC, REST ,GraphQL区别比较优劣

    其实在使用和学习的过程中,有很多文章都对比过它们的异同,但是大部分文章并没有从一个相对客观的角度来对比,更多是为了突显一个的优点而刻意指出另外一个的缺点。这让我想到一句话,脱离业务情景谈技术就是耍流氓。

  • 2019-12-23 23:38:59

    vue-apollo的多客户端的用法

    vue-apollo的多客户端的用法以及apollo.js的配置 关于如何安装和如何使用,这篇文章就先暂时不介绍了,如果不清楚就看我另一篇关于vue-apollo的用法 在做项目中,有时候后端的接口是按模块功能去划分的,那么请求的地址就会不同,关于vue-apollo的多客户端配置如下

  • 2019-12-27 08:40:55

    align-self和align-items的区别

    align-items在伸缩容器上使用它,伸缩容器内部所有的元素都一致地受制于align-items的值。 但是有些时候,我们希望伸缩容器内部某个元素在侧轴上的排列方式有所差异。此时就不能使用 align-items,因为align-items作用于整体。我们希望作用于部分。这就是align-self的发挥场地。