我的编程空间,编程开发者的网络收藏夹
学习永远不晚

PHP消息队列实现及运用的方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

PHP消息队列实现及运用的方法是什么

这篇文章主要讲解了“PHP消息队列实现及运用的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP消息队列实现及运用的方法是什么”吧!

消息队列的概念、原理、实现方式

概念
  • 队列结构的一个中间件

  • 不需要立即消费消息

  • 由消费者或者订阅者进行按顺序消费

基本的流程图如下所示
  • 流程
    PHP消息队列实现及运用的方法是什么

应用场景
  • 冗余

  • 解耦

  • 流量削峰

  • 异步通信

实现方式
  • mysql:可靠、速度慢

  • redis:速度快,对于大消息包处理较慢

  • 消息系统:可靠、专业性强

消息的触发机制
  • 死循环的方式,故障时无法及时恢复

  • 定时任务:压力均分、但是处理量有上限

  • 守护进程的方式

解耦 (订单和配送系统)
  • 架构设计1 采用定时任务的方式
    PHP消息队列实现及运用的方法是什么

    php入门到就业线上直播课:进入学习
    Apipost = Postman + Swagger + Mock + Jmeter 超好用的API调试工具:点击使用

  • 使用配送处理系统进行处理时,将当前数据库里需要处理的订单状态更新为2,待处理完成后将状态设为1

  • 可以每次指定更新多少条数据

流量削锋 (redis实现秒杀)
  • 使用队列的数据结构

    • lpush/rpush 将数据放入列表中

    • lpop/rpop 将数据移除列表并获取到移除的值

    • ltrim 保留指定区间内的元素

    • llen 获取列表长度

    • lset 通过索引设置列表的值

    • lindex 通过索引获取列表中的值

    • lrange 获取指定范围的元素

  • 图示如下
    PHP消息队列实现及运用的方法是什么

  • 代码流程如下

    • 秒杀程序将请求写入redis(uid,time)

    • 检查redis列表存放的长度,超过10个直接舍弃

    • 通过死循环读取redis数据,并存入数据库

      // Spike.php 秒杀程序if(Redis::llen('lottery') < 10){
         // 成功
         Redis::lpush('lottery', $uid.'%'.microtime());}else{
         // 失败}
    • // Warehousing.php 入库程序while(true){
          $user = Redis::rpop('lottery');
          if (!$user || $user == 'nil') {
              sleep(2);
              continue;
          }
          $user_arr = explode($user, '%');
          $insert_user = [
              'uid' => $user_arr[0],
              'time' => $user_arr[1]
          ];
          $res = DB::table('lottery_queue')->insert($insert_user);
          if (!$res) {
              Redis::lpush('lottery', $user);
          }}
  • 上述代码中假如并发过大的话会存在超卖的情况,此时可以使用文件锁或者redis分布式锁进行控制,先将商品放入redis list中 使用rpop进行取出,如果取不到则说明已经卖完

  • 具体的思路及伪代码如下

      // 先将商品放入redis中
     $goods_id = 2;

     $sql = select id,num from goods where id = $goods_id;
     $res = DB::select($sql);
     if (!empty($res)) {
         // 也可以指定多少件
         Redis::del('lottery_goods' . $goods_id);
         for($i=0;$i<$res['num'];$i++){
             Redis::lpush('lottery_goods . $goods_id', $i);
         }
         LOG::info('商品存入队列成功,数量:' . Redis::llen('lottery_goods . $goods_id'));
     } else {
         LOG::info($goods_id . '加入失败');
     }
  •   // 开始秒杀
      $count = Redis::rpop('lottery_goods' . $goods_id);
      if (!$count) {
          // 商品已抢完
          ...
      }

      // 用户抢购队列
      $user_list = 'user_goods_id_' . $goods_id;
      $user_status = Redis::sismember($user_list, $user_id);
      if ($user_status) {
          // 已抢过
          ...
      }

      // 将抢到的放到列表中
      Redis::sadd($user_list, $uid);
      $msg = '用户:' . $uid . '顺序' . $count;
      Log::info($msg);
      // 生成订单等
      ...
      // 减库存
      $sql = update goods set num = num -1 where id = $goods_id and num > 0; // 防止超卖
      DB::update($sql)
      // 抢购成功
rabbitmq
  • 架构及原理
    PHP消息队列实现及运用的方法是什么
    其中P代表生产者,X为交换机(channal),C代表消费者

  • 简单使用

      // Send.php
     require_once __DIR__.'/vendor/autoload.php';

     use PhpAmqpLib\Connection\AMQPStreamConnection;
     use PhpAmqpLib\Message\AMQPMessage;

     $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');

     // 创建通道
     $channel = $connection->channel();
     // 声明一个队列
     $channel->queue_declare('user_email', false, false, false, false);
     // 制作消息
     $msg = new AMQPMessage('send email');
     // 将消息推送到队列
     $channel->basic_publish($msg, '', 'user_email');

     echo '[x] send email';

     $channel->close();
     $connection->close();
  •   // Receive.php
      require_once __DIR__.'/vendor/autoload.php';

      use PhpAmqpLib\Connection\AMQPStreamConnection;
      use PhpAmqpLib\Message\AMQPMessage;

      $connection = new AMQPStreamConnection('localhost', 5672, 'guest', 'guest');

      //创建通道
      $channel = $connection->channel();

      $channel->queue_declare('user_email', false, false, false, false);

      // 当收到消息时的回调函数
      $callback = function($msg){
          //发送邮件
          echo 'Received '.$msg->body.'\n';
      };

      $channel->basic_consume('user_email', '', false, true, false, false, $callback);

      // 保持监听状态
      while($channel->is_open()){
          $channel->wait();
      }

感谢各位的阅读,以上就是“PHP消息队列实现及运用的方法是什么”的内容了,经过本文的学习后,相信大家对PHP消息队列实现及运用的方法是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

PHP消息队列实现及运用的方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

PHP消息队列实现及运用的方法是什么

这篇文章主要讲解了“PHP消息队列实现及运用的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP消息队列实现及运用的方法是什么”吧!消息队列的概念、原理、实现方式概念队列结构的一
2023-07-04

Redis消息队列实现的方法是什么

Redis消息队列通常通过使用Redis的List数据结构来实现。消息生产者可以将消息推送到List中,而消息消费者可以从List中获取消息进行处理。通过使用Redis的原子操作来实现消息的生产和消费,可以确保消息队列的高效性和可靠性。一些
Redis消息队列实现的方法是什么
2024-04-22

SpringBoot整合消息队列RabbitMQ的方法是什么

本篇内容介绍了“SpringBoot整合消息队列RabbitMQ的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!简介在Spring
2023-07-05

队列在PHP与MySQL中的消息过滤和消息路由的实现方法

随着互联网的快速发展,消息队列(Message Queue)作为一种重要的通信机制,在Web开发中扮演着至关重要的角色。消息队列可以用于实现解耦、削峰填谷、异步处理等功能。本文将介绍在PHP与MySQL中如何实现消息过滤和消息路由,并提供具
2023-10-21

Java中消息队列的作用是什么

这篇文章主要讲解了“Java中消息队列的作用是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中消息队列的作用是什么”吧!1、 这些接口之间耦合比较严重,每新增一个下游功能,都要
2023-06-16

WCF消息队列的解决方案是什么

WCF消息队列的解决方案是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。消息就是信息的来源,在WCF中消息队列分为公共队列、专用队列、管理队列、响应队列四种,下面我们就简单
2023-06-17

队列的消息保障和消息持久化在PHP与MySQL中的实现方法

【引言】在互联网时代,随着用户量的增长和系统复杂性的增加,消息队列成为了重要的组件之一。消息队列可以实现解耦、异步处理、削峰填谷等功能,提高系统的稳定性和可扩展性。在实际应用中,我们常常需要考虑消息的可靠性和持久化存储。本文将介绍如何在PH
2023-10-21

java消息队列mq的使用场景是什么

Java消息队列(MQ)的使用场景主要包括以下几个方面:1. 异步通信:当系统中的不同模块之间需要进行异步通信时,可以使用消息队列来实现。例如,订单系统和库存系统之间的通信,订单系统生成订单后将消息放入消息队列,库存系统从消息队列中获取订单
2023-10-09

队列的消息确认和消费失败处理在PHP与MySQL中的实现方法

队列是一种常见的消息传递机制,它可以帮助解决系统中的高并发问题,实现异步处理和解耦。在队列的设计中,消息的确认和消费失败处理是非常重要的环节。本文将探讨使用PHP与MySQL实现队列的消息确认和消费失败处理的方法,并提供具体的代码示例。消息
2023-10-21

队列技术在PHP与MySQL中的消息序列化和反序列化的实现方法

在Web开发中,队列技术被广泛应用于处理异步任务和消息传递,能够提高系统的性能和可扩展性。PHP作为一种流行的服务器端编程语言,与MySQL数据库结合使用,可以实现优秀的Web应用。本文将介绍队列技术在PHP与MySQL中的消息序列化和反序
2023-10-21

Redis实现延迟队列的方法是什么

这篇文章主要介绍“Redis实现延迟队列的方法是什么”,在日常操作中,相信很多人在Redis实现延迟队列的方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Redis实现延迟队列的方法是什么”的疑惑有所
2023-07-05

php操作redis队列的方法是什么

PHP操作Redis队列本教程介绍PHP中使用Redis操作队列的方法,包括入队、出队、批量操作、查看队列长度、阻塞出队、事务处理、使用管道、使用队列列表、使用发布/订阅以及RedisInsight。
php操作redis队列的方法是什么
2024-04-10

php操作redis队列的方法是什么

PHP操作Redis队列的方法主要有以下几种:1. LPUSH/RPUSH:将一个或多个元素插入到列表的左侧或右侧。LPUSH是从列表的左侧插入元素,RPUSH是从列表的右侧插入元素。2. LPOP/RPOP:从列表的左侧或右侧弹出一个元素
2023-08-29

redis队列实现高并发的方法是什么

在Redis中实现高并发的队列,可以使用Redis的list数据结构来实现队列的功能。具体步骤如下:使用LPUSH命令将数据推入队列:客户端将需要处理的数据通过LPUSH命令推入一个队列的头部。使用BRPOP命令从队列中取出数据:客户端使用
redis队列实现高并发的方法是什么
2024-04-09

Java单向队列及环形队列的实现原理是什么

这篇文章主要介绍“Java单向队列及环形队列的实现原理是什么”,在日常操作中,相信很多人在Java单向队列及环形队列的实现原理是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java单向队列及环形队列的实
2023-06-25

java中的消息队列怎么利用多线程实现

java中的消息队列怎么利用多线程实现?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、定义一个队列缓存池: //static修饰的成员变量和成员方法独立于该类的任何对象。也就
2023-05-31

Java队列数据结构的实现方法是什么

这篇文章主要介绍“Java队列数据结构的实现方法是什么”,在日常操作中,相信很多人在Java队列数据结构的实现方法是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java队列数据结构的实现方法是什么”的疑
2023-06-22

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录