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-08-06 15:30:08

    小程序展示富文本

    然而rich-text有个问题,它不能够给内联img设置宽度100%,这样图片就容易溢出屏幕。我们只能在后台返回富文本的时候对图片的img标签进行格式化。或者前端进行格式化也行,我赞成使用后端,因为很多种情况我们不一定都能想得到。

  • 2019-08-07 09:07:32

    最全的Service Worker讲解

    Service Worker 最主要的特点是:在页面中注册并安装成功后,运行于浏览器后台,不受页面刷新的影响,可以监听和截拦作用域范围内所有页面的 HTTP 请求。 基于 Service Worker API 的特性,结合 Fetch API、Cache API、Push API、postMessage API 和 Notification API,可以在基于浏览器的 web 应用中实现如离线缓存、消息推送、静默更新等 native 应用常见的功能,以给 web 应用提供更好更丰富的使用体验。

  • 2019-08-07 09:09:19

    windows系统下定时关闭程序

    其中xxx.exe是你要关闭的进程中运行的exe,可以ctrl+alt+del打开任务管理器,进到详细信息查看 然后把.txt文件后缀改成.bat(此时要在查看一栏勾上文件拓展名,要不还是txt文档)

  • 2019-08-07 09:16:43

    一个比较完美的PWA例子

    但就目前来讲,PWA是Google主推的一项技术标准,FireFox,Chrome以及一些基于Blink的浏览器已经支持渐进式Web应用了,Edge上对渐进式Web应用的支持还在开发。Apple公司也表示会考虑在自己Safari支持PWA。然而这项功能已经进入了WebKit内核的五年计划中。长期来看,对浏览器兼容性的支持方面应该已经不算太大问题了。况且在现阶段,在不支持渐进式Web应用的浏览器中,你的应用也只是无法使用渐进式Web应用的离线功能而已,除此之外的功能均可以正常使用。

  • 2019-08-07 09:57:48

    spring data jpa 实体类中字段不与数据库表映射

    当我们使用spring data jpa开发的时候,会将实体类中的成员变量与表中的字段一一对应,当我们在实体类中加上一个不与数据库表一一对应的成员变量的时候,此时我们只要在这个成员变量上加上注解@Transient @

  • 2019-08-07 17:16:53

    如何在 Node.js 中使用 import / export 的三种方法

    因为一些历史原因,虽然 Node.js 已经实现了 99% 的 ES6 新特性,不过截止 2018.8.10,How To Enable ES6 Imports in Node.JS 仍然是老大难问题,下面我来介绍三种方法可以让我们在 Node.js 中使用 import/export 。

  • 2019-08-13 08:56:46

    nuxtjs组合element

    添加elementUI 插件,plugins->ele.js,代码如下

  • 2019-08-13 20:06:42

    修改 Nginx 进程最大可打开文件数(worker_processes和worker_connections)

    worker_processes:操作系统启动多少个工作进程运行Nginx。注意是工作进程,不是有多少个nginx工程。在Nginx运行的时候,会启动两种进程,一种是主进程master process;一种是工作进程worker process。例如我在配置文件中将worker_processes设置为4,启动Nginx后,使用进程查看命令观察名字叫做nginx的进程信息,我会看到如下结果: