基础概念介绍
stream:每个Stream都有唯一的名称,它就是Redis的key;
group:每个 Stream 都可以挂多个消费组;每个消费组 (Consumer Group) 的状态都是独立的,相互不受影响。也就是说同一份Stream 内部的消息会被每个消费组都消费到;
consumer:同一个消费组 (Consumer Group) 可以挂接多个消费者 (Consumer),这些消费者之间是竞争关系,即一条消息仅可被一个组内的一个消费者消费。每个消费者有一个组内唯一名称。
基础组件代码
1 | import org.springframework.beans.factory.annotation.Autowired; |
消息队列配置代码
1 | import org.springframework.data.redis.connection.stream.MapRecord; |
1 | /** |
以上是两个不同的消息监听器处理,配合以下的配置代码使用,具体使用需要根据场景选择:
1 | import org.springframework.beans.factory.annotation.Autowired; |