功能:是一个可持久化的消息队列。
基础概念介绍:
stream:每个Stream都有唯一的名称,它就是Redis的key;
group:每个 Stream 都可以挂多个消费组;每个消费组 (Consumer Group) 的状态都是独立的,相互不受影响。也就是说同一份Stream 内部的消息会被每个消费组都消费到;
consumer:同一个消费组 (Consumer Group) 可以挂接多个消费者 (Consumer),这些消费者之间是竞争关系,即一条消息仅可被一个组内的一个消费者消费。每个消费者有一个组内唯一名称。不同组是可以全面消费的(重复消费),同一组内会发生竞争关系,只有其中一个可以消费。
基础组件代码:
/**
* 对redis stream命令的一些实现,可单独使用
*
* @author cheneq
*/
@Slf4j
@Component
public class RedisStream {
@Autowired
private StringRedisTemplate redisTemplate;
/**
* 创建消费组
*
* @param key
* @param group
* @return
*/
public String creartGroup(String key, String group) {
return redisTemplate.opsForStream().createGroup(key, group);
}
/**
* 消费组信息
*
* @param key
* @param group
* @return
*/
public StreamInfo.XInfoConsumers consumers(String key, String group) {
return redisTemplate.opsForStream().consumers(key, group);
}
/**
* 确认已消费
*
* @param key
* @param group
* @param recordIds
* @return
*/
public Long ack(String key, String group, String... recordIds) {
return redisTemplate.opsForStream().acknowledge(key, group, recordIds);
}
/**
* 追加消息
*
* @param key
* @param field
* @param value
* @return
*/
public String add(String key, String field, Object value) {
Map<String, Object> content = new HashMap<>(1);
content.put(field, value);
return add(key, content);
}
public String add(Stri