RabbitMQ 入门三(Work Queues)

上次我们简单的实现了发送与接收消息,接下来我们将学习更高级的用法。

假如现在有这样的一个应用场景,有大量的密集计算需要后台去完成,单一的进程速度稍慢,这时候我们就需要多进程去协作完成了。

现在我们建一个名为producer2.php的文件,用来发送消息,内容如下。

接下来我们再来建立一个名为concumer2.php的文件,用来接收消息,内容如下。

我们开启两个consumer2.php的进程,再来通过producer2.php发送消息

我们可以看到 ,两个consumer的进程是顺序的接收消息的。

    这里牵涉到了RabbitMq的消息确认机制,默认情况下,RabbitMQ 会顺序的分发每个Message。当每个收到ack后,会将该Message删除,然后将下一个Message分发到下一个Consumer。这种分发方式叫做round-robin。

     与producer1.php不同的是,我们这里申明队列的时候,第三个参数设置成为了true,意思为当消息确认(Message acknowledgment)之后,才能从队列里删除,这样做的好处是为了防止处理消息的cosumer一旦处理到一半发生意外关闭,导致此条消息被删掉而真正要做的任务却没有完成。

     另外我们这里还开起了消息持久化(Message durability),消息创建的时候会把消息备份到硬盘上,以确保消息队列的意外关闭重启也能找到消息,当然持久化也不是非常保险的,因为备份到硬盘也是需要时间的,一旦这个时候消息队列意外关闭,消息就丢失了,当然这种情况非常少数,但是预防这种情况,我们可能需要自己做事务(transaction),以确保消息的绝对安全。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值