之前是用官方提供的方法来处理的

``

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

while(count($channel->callbacks)) {

$channel->wait();

}

``

发现中断程序的时候 每个消息没有被完全处理完,比如拿到消息还没有处理完入库就被中断了。

后来打算用libevent 据说在事件处理中,除非强制kill掉,不然事件会处理完再中断,但是以下代码还是不断报错;

``

$this->connection = new AMQPStreamConnection($config['host'], $config['port'], $config['user'], $config['password'], $config['vhost']);

$this->channel = $this->connection->channel();;

$this->channel->queue_declare($queue, false, true, false, false);

// $this->channel->basic_consume($queue, '', false, true, false, false, function ($msg) {

// set_trace_prefix(md5($msg->body . time()));

// trace('receive msg:' . $msg->body);

// trace('done');

// });

$ch = $this->channel;

$fd = $this->connection->getSocket();

Worker::$globalEvent->add($fd, EventInterface::EV_READ, function ($fd) use ($queue, $ch){

$msg = $ch->basic_get($queue, true);

print_r($msg);

print("get a messge:\n");

});

``

php如何防止消息被篡改,php如何用libevent处理rabbitmq发来的消息,防止消息丢失或者人为的中断导致消息没有被处理完整...相关推荐

  1. 各个MQ消息队列介绍以及区别比较(RabbitMq ActiveMQ、ZeroMQ、Kafka)

    首先,MQ其实就是消息队列,队列我们可以理解为管道,以管道的方式做消息传递. 在本篇博客中,我们先来简单学习一下几种MQ,之后对他们进行对比. ActiveMQ.RabbitMQ.kafka.Rock ...

  2. RocketMQ如何保证消息不丢失? 如何快速处理积压消息?

    文章目录 1. 哪些环节会有丢消息的可能? 2. 消息生产阶段如何保证消息不丢失 2.1 同步发送 2.2 采用事务消息 3. Broker如何保证接收到的消息不会丢失 4. 消费者如何确保拉取到的消 ...

  3. activemq消息丢失_基于Redis实现消息队列的典型方案

    基于Redis实现消息队列典型方案 1 概述 2 基于List的 LPUSH+BRPOP 的实现 3 PUB/SUB,订阅/发布模式 4 基于SortedSet有序集合的实现 5 基于 Stream ...

  4. java给朋友发微信_微信api接口,给微信好友收发消息

    微信api接口,给微信好友收发消息 /** * 给微信好友发消息 * @author wechatno:tangjinjinwx * @blog http://www.wlkankan.cn */ @ ...

  5. 【消息中间件MQ系列】消息队列之ActiveMQ、RocketMQ、RabbitMQ、Kafka不得不说的秘密

    热门系列: [消息中间件MQ系列]RabbitMQ安装与使用,并与SpringBoot整合 程序人生,精彩抢先看 目录 1.消息队列/消息中间件介绍 1.1 消息中间件是什么 1.1.1 消息中间件的 ...

  6. RabbitMQ 服务异步通信 -- 入门案例(消息预存机制)、SpringAMQP、发布订阅模式(FanoutExchange、DirectExchange、TopicExchange)、消息转换器

    文章目录 1. 入门案例 2. 完成官方Demo中的hello world案例 2.1 创建1个工程,2个模块 2.1.1 父工程的依赖,子工程不需要导入额外的依赖 2.1.2 配置子工程的配置文件( ...

  7. 消息队列超详解(以RabbitMQ和Kafka为例,为何使用消息队列、优缺点、高可用性、问题解决)

    消息队列超详解(以RabbitMQ和Kafka为例) 为什么要用消息队列这个东西? 先说一下消息队列的常见使用场景吧,其实场景有很多,但是比较核心的有3个:解耦.异步.削峰. 解耦:现场画个图来说明一 ...

  8. 怎么做一个定时消息提醒_如何用Nodejs编写一个定时消息提醒应用?

    背景: 同事告诉我最近一段时间每天上班长时间盯着屏幕工作经常眼睛疼,问我有没有好用定时提醒功能.我受到启发,决定用nodejs来实现一个定时提醒应用. 需求分析: 同事是个程序员,熟悉命令行操作,这样 ...

  9. 消息队列系列(三):.Rabbitmq Trace的使用

    一.什么是Trace Trace是Rabbitmq用于记录每一次发送的消息,方便使用Rabbitmq的开发者调试.排错.可通过插件形式 提供可视化界面 二.Trace实现概况 1.Trace启动后会自 ...

最新文章

  1. Android 进阶自定义View(4)图表统计LineChartView曲线图的实现
  2. Java 实现滑动时间窗口限流算法,你见过吗?
  3. SAP创建中国版免费在线课程openSAP
  4. ftp获取远程Pdf文件
  5. MySQL count()函数
  6. UNIX(进程间通信):01---Linux进程通信方式
  7. 【数据结构、算法】八大排序算法概述(算法复杂度、稳定性)
  8. PyTorch 1.5上线:加入稳定C++前端,高级自动梯度API
  9. TypeError: keys must be str, int, float, bool or None, not tuple,解决 python 中 json 保存不了字典键值为 元组 的问题
  10. Python--day34--前面网络编程的复习
  11. SD从零开始29-30
  12. Motion camera 真人动作捕捉器
  13. 将base64格式的图片下载到本地
  14. JSON Viewer丨Json格式查看器
  15. Spring学习的书-夏昕(2)
  16. 应届生web前端面试题_前端开发应届生面试指南(含各大公司具体指南及面试真题)...
  17. 2021年中国非接触式传感设备市场趋势报告、技术动态创新及2027年市场预测
  18. word文档中如何将软回车替换为硬回车
  19. 加州大学戴维斯计算机博士生,2020年加州大学戴维斯分校博士读几年
  20. 电脑安装android2.0,应用多开 这才是最适用电脑的安卓—凤凰系统2.0

热门文章

  1. 升级TortoiseSVN-1.9.0.26652-x64-svn-1.9.0导致错误提示
  2. corosync+pacemaker+drbd构建mysql高可用平台的简单案例
  3. Date String转换
  4. 方法对象java final关键字的用法
  5. Silverlight 和WPF的Composite Guidance(Prism V2)发布了
  6. 解决java.lang.UnsupportedClassVersionError: Bad version number in .class file问题
  7. golang 获取文件行数
  8. linux shell 把一个文件的前n行 拷贝到另一个文件中
  9. java 反序列化 ysoserial exploit/JRMPClient 原理剖析
  10. python3 判断进程是否存在