Laravel使用消息队列需要注意的一些问题_php实例

韦小宝
发布: 2017-12-15 09:36:52
原创
1503人浏览过

这篇文章主要给大家介绍了关于laravel使用消息队列需要注意的一些问题,文中通过laravel示例代码介绍的非常详细,对大家的学习laravel具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧。

前言

消息队列对于大型的Web项目来说是必不可少的一个模块,通过消息队列可以解决大并发和多种语言通信接口等问题。对于大并发的问题,可以将耗时的任务或者不能同时大量并行的任务封装起来传输到消息队列中,由处理程序不断从消息队列中提取消息并进行处理,这样通过消息队列的缓冲可以使得在大并发情况下不再阻塞,如果性能不够用还可以添加多个处理任务从消息队列中获取消息进行处理。比如数据库的操作,当对数据库的读、写操作过多时就会存在锁表等问题,读的问题可以通过缓存等方案解决,写的问题就需要消息队列来解决。而且,在大型的Web项目开发中,很多情况下不可能通过一种语言实现,需要发挥不同语言的优势,比如PHP,虽然在理论意义上它可以做Web开发中的所有事情,但是有些问题用它解决效率将会非常低,比如实时socket连接和分布式事务处理等。

使用 Laravel 的消息队列处理异步任务,Redis 作为队列数据库,Supervisor 监控脚本异常中断并自动重启,这是 Laravel 处理队列任务的标准流程,但是实际中可能还会出现各种各样的问题,为了保证系统可靠性,还要注意几个问题。

一、执行失败重试次数设置

立即学习PHP免费学习笔记(深入)”;

一定要设置任务执行失败重试次数,避免无限失败重试,超过重试次数 Laravel 会默认写到失败任务表中,也可以自己写执行失败后续处理逻辑。


php artisan queue:work redis --tries=3
登录后复制

需要先执行以下命令创建数据表:


php artisan queue:failed-table
php artisan migrate
登录后复制

二、程序异常的处理

有时候程序执行过程会发生异常,比如依赖其他接口,请求 HTTP 接口超时等等,如果不捕捉异常,那么当前这个队列就会中断不能继续运行下去,比如给 10000 个用户推送内容,需要依赖接口推送,如果中间的请求挂了就会影响到后面的推送。

这里的异常是指程序执行过程中发生的异常,不是指常驻进程挂掉,程序异常不一定导致常驻进程中断,况且进程中断有 Supervisor 监控并重启。

如捕获异常代码片段:


try {
 $r = $client->request('POST', '', [
  'query' => [
   'client_name'  => 'filemail',
   'client_version' => '1.0',
   'client_sequence' => 0,
   'uid'    => 692934013,//119481237
   'r'    => 1508312484,
  ],
  'body' => GuzzleHttpjson_encode($body),
 ]);
 $result = $r->getBody()->getContents();
 $result = json_decode($result, true);
 if ($result['result'] == 0) {
  info("sendMail fail:" . json_encode($result));
  $this->pushLog($task['id'], $task['mail_id'], implode(',', $userIds), json_encode($result), 0);
 } else {
  Log::warning("sendMail fail:" . json_encode($result));
  $this->pushLog($task['id'], $task['mail_id'], implode(',', $userIds), json_encode($result), $result['result']);
 }
} catch (RequestException $e) {
 Log::warning('RequestException' . $e->getMessage());
} catch (Exception $e) {
 Log::emergency('Exception' . $e->getMessage());
}
登录后复制

三、修改代码记得重启 Supervisor

最后一点,修改了处理队列的程序,记得要重启 Supervisor,否则脚本不会生效。

Chatbase
Chatbase

从你的知识库中构建一个AI聊天机器人

Chatbase 69
查看详情 Chatbase

Laravel 往 Redis 写队列的数据结构

队列用 list 类型存储,如图:

 

value 内容如下:


{
 "job": "Illuminate\Queue\CallQueuedHandler@call",
 "data": {
 "commandName": "App\Jobs\SendFile",
 "command": "O:17:"App\Jobs\SendFile":5:{s:23:"u0000App\Jobs\SendFileu0000task";a:8:{s:5:"title";s:4:"1111";s:4:"note";s:2:"11";s:6:"reward";s:0:"";s:7:"mail_id";s:5:"66681";s:4:"nums";i:20;s:8:"uid_file";s:33:"uidfile/file-66681-1513058185.txt";s:5:"gcids";s:40:"1B9DD95645AAE8119F7DA9B9FF738D52BC8A1BD5";s:2:"id";i:29;}s:6:"u0000*u0000job";N;s:10:"connection";N;s:5:"queue";s:8:"sendfile";s:5:"delay";N;}"
 },
 "id": "l0mjsUthbxm4TgIJNUH13km9N8DIpErK",
 "attempts": 1
}
登录后复制

包含失败重试次数,队列标识,处理队列的类,以及队列的数据等等。

参考链接

Laravel 官方文档 Queue 队列:

https://laravel.com/docs/5.5/queues

以上就是本文的所有内容了,希望对同学们学习Laravel提供到帮助!!

相关推荐:

关于Laravel使用消息队列需要注意哪些?

Laravel 进行微信支付开发实例

laravel查询构造器Query Builder叠加链式调用的方法教程

以上就是Laravel使用消息队列需要注意的一些问题_php实例的详细内容,更多请关注php中文网其它相关文章!

相关标签:
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号