-
publish/subscribe的用法
redis提供了如下6个命令来支持该功能:subscribe subscribe channel [channel …] 订阅一个或多个频道
unsubscribe unsubscribe [channel [channel …]] 退订频道,如果没有指定频道,则退订所有的频道
publish publish channel message 给指定的频道发消息
psubscribe psubscribe pattern [pattern …] 订阅给定模式相匹配的所有频道
punsubscribe punsubscribe [pattern [pattern …]] 退订给定的模式,如果没有指定模式,则退订所有模式 -
实现原理
-
实现过期优惠卷处理
-
代码实现
1)首先构造一个自定义的监听器
/**
*
* @author FJW
* onmessage:处理消息
* message:完整的消息
* pattern:获取的频道信息
*
*/
public class RedisMessageListener implements MessageListener {
@Override
public void onMessage(Message message, byte[] panttern) {
System.out.println("从channel为:"+new String(message.getChannel())+"获取一条新的消息,消息内容为:"+new String(message.getBody()));
}
}
2)配置applicationContext.xml文件
<!-- 监听器的适配器 -->
<bean class="org.springframework.data.redis.listener.adapter.MessageListenerAdapter" id="messageListener">
<constructor-arg>
<!-- 注入自定义的监听器 -->
<bean class="com.test.Listern.RedisMessageListener"></bean>
</constructor-arg>
</bean>
<!-- 配置监听容器 -->
<bean class="org.springframework.data.redis.listener.RedisMessageListenerContainer" id="redisContainer">
<!--
由于需要redis进行交互,注入连接工厂
1.订阅的消息主题
2.接收到消息之后处理的监听器
-->
<property name="connectionFactory" ref="connectionFactory"/>
<property name="messageListeners">
<map>
<entry key-ref="messageListener">
<!-- topic的集合:订阅的主题 publish/subscribe ///notify-keyspace-events Ex
订阅了一个主题消息:主题的名称(ITCAST) /_keyevent@0__:expired redis提供的名称,标识过期消息通知
接受到一条消息之后,交由自定义的消息监听器来进行处理
-->
<list>
<bean class="org.springframework.data.redis.listener.ChannelTopic">
<constructor-arg value="_keyevent@0__:expired"></constructor-arg>
</bean>
</list>
</entry>
</map>
</property>
</bean>