data:image/s3,"s3://crabby-images/ddedd/ddeddf12bdeb02a0bef23a4ec9d9da260cb816da" alt=""
redis 的list类型实现消息队列:
data:image/s3,"s3://crabby-images/4f9ff/4f9ff4aca03a81edc9dede5bfc98390107c99239" alt=""
list结构实现的优缺点:
data:image/s3,"s3://crabby-images/40e1c/40e1c774c88c52dd2ab67fa289cb2fd665cd1cf3" alt=""
data:image/s3,"s3://crabby-images/da6ca/da6ca1724c2b2058b05089580e54d4e014555440" alt=""
data:image/s3,"s3://crabby-images/7e877/7e8770c88ff4431e7b3354a462550f5b74d48bd7" alt=""
2、pubsub模式(消息发布订阅)实现消息队列
data:image/s3,"s3://crabby-images/f4edf/f4edfa1db3ed012ffe0346fccac3bcb130e01868" alt=""
pubsub的优缺点:
data:image/s3,"s3://crabby-images/d4639/d46391a4ccc68e63e3e2172552fbdf9f00ce52c0" alt=""
命令行实现:
pub:第一次发送有两个接收,第二个只有一个接收
data:image/s3,"s3://crabby-images/cdb90/cdb9085327ab32aa2958335191a50ce1be1bc45d" alt=""
sub接收:
第一个sub接收的信息通道(order.p1)使得pub发送第二次消息没有接受到
data:image/s3,"s3://crabby-images/f8d5d/f8d5d7807e9058774f9d2b6692ff90241a34df26" alt=""
第二个sub接收的频道(order.*)接收order.后面所有的频道,使得两次pub发送的消息都接收到了
data:image/s3,"s3://crabby-images/1f4da/1f4da318bcf8bc30753cf6184d7b06dc15abfe87" alt=""
stream实现消息队列:
data:image/s3,"s3://crabby-images/bc005/bc005211dd9693eba98fbf60fadc05867c29ae28" alt=""
data:image/s3,"s3://crabby-images/04cd9/04cd9566af493aeec7bffdf5e91967a91c1d4d07" alt=""
具体的实现:
data:image/s3,"s3://crabby-images/234ca/234ca8ad5e4e935f11c7f07db9ba4df43442f824" alt=""
往里面存数据:
data:image/s3,"s3://crabby-images/cf17a/cf17a521c1c42da79a760944da8046f1fba96373" alt=""
$:则实时取数据,在消息存放的时候才会获取
data:image/s3,"s3://crabby-images/3bf2b/3bf2badd87f5648a0919b8a0f5f21d157635113f" alt=""
0:取第一个数据,始终取第一个数据
优缺点:
4、消息费者组(consumer Group):
data:image/s3,"s3://crabby-images/c1952/c195217ef8f260953b3a050e71afd63ff50f0790" alt=""
创建一个消费者组: XGROUP CREATE s1 g1 $ (s1队列名称,g1消费者组的名称)
data:image/s3,"s3://crabby-images/c487a/c487a9b96435837d6108d43245e8152c05e000b5" alt=""
消息消费者命令:
data:image/s3,"s3://crabby-images/d6d61/d6d61c43506ebb5f9cb3dbf4df6d14afc3a8833b" alt=""
确认消息命令:XACK key group ID [ID ...] (如果消息只是拿到,没有确认的话,消息会存放在expending-list里面)
查看pending-list的命令:XPENDING key group [[IDLE min-idle-time] start end count [consumer]]
stream group的优点:
data:image/s3,"s3://crabby-images/1c873/1c8738c1f85008d7f6380e136397b51cc06ef7f2" alt=""
三种实现消息队列的比较:
data:image/s3,"s3://crabby-images/9d18b/9d18b82632f662623006f23dcce3f11877c2b26f" alt=""
5、通过streamGroup消费者组,就可以实现消息队列(通过java和lua脚本)