最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

redis的发布订阅功能

来源:动视网 责编:小采 时间:2020-11-09 06:57:17
文档

redis的发布订阅功能

redis的发布订阅功能:序redis提供了简单的发布订阅功能,对于一些合适的场景(比如不要求消费者不在线时也能收到离线消息),比起专业的MQ来说,用起来更简单些。本文主要是记录下怎么在SpringBoot里头使用redis的发布订阅功能。定义生产者配置@Bean MyPublisher red
推荐度:
导读redis的发布订阅功能:序redis提供了简单的发布订阅功能,对于一些合适的场景(比如不要求消费者不在线时也能收到离线消息),比起专业的MQ来说,用起来更简单些。本文主要是记录下怎么在SpringBoot里头使用redis的发布订阅功能。定义生产者配置@Bean MyPublisher red


redis提供了简单的发布订阅功能,对于一些合适的场景(比如不要求消费者不在线时也能收到离线消息),比起专业的MQ来说,用起来更简单些。本文主要是记录下怎么在SpringBoot里头使用redis的发布订阅功能。

定义生产者

配置

@Bean
 MyPublisher redisPublisher(RedisConnectionFactory factory) {
 return new MyPublisher( redisTemplate(factory), topic() );
 }
 @Bean
 ChannelTopic topic() {
 return new ChannelTopic( "pubsub:queue" );
 }

生产者实例

public class MyPublisher {
 private final RedisTemplate< String, Object > template;
 private final ChannelTopic topic;
 private final AtomicLong counter = new AtomicLong( 0 );
 public MyPublisher( final RedisTemplate< String, Object > template,
 final ChannelTopic topic ) {
 this.template = template;
 this.topic = topic;
 }
 @Scheduled( fixedDelay = 100 )
 public void publish() {
 template.convertAndSend( topic.getTopic(), "Message " + counter.incrementAndGet() +
 ", " + Thread.currentThread().getName() );
 }
}

定义消费者

配置

//subscribe
 @Bean
 MessageListenerAdapter messageListener() {
 return new MessageListenerAdapter( new MyMessageListener() );
 }
 @Bean
 RedisMessageListenerContainer redisContainer(RedisConnectionFactory factory) {
 final RedisMessageListenerContainer container = new RedisMessageListenerContainer();
 container.setConnectionFactory(factory);
 container.addMessageListener(messageListener(), topic());
 return container;
 }

消费者实例

public class MyMessageListener implements MessageListener {
 @Override
 public void onMessage( final Message message, final byte[] pattern ) {
 System.out.println( "Message received: " + message.toString() );
 }
}

运行

 . ____ _ __ _ _
 /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/ ___)| |_)| | | | | || (_| | ) ) ) )
 ' |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot :: (v1.3.2.RELEASE)
2016-02-16 00:14:08.190 INFO 1481 --- [ main] com.codecraft.RedisdemoApplication : Starting RedisdemoApplication on Jupiter.local with PID 1481 (/Users/codecraft/workspace/redisdemo/target/classes started by codecraft in /Users/codecraft/workspace/redisdemo)
2016-02-16 00:14:08.193 INFO 1481 --- [ main] com.codecraft.RedisdemoApplication : No active profile set, falling back to default profiles: default
2016-02-16 00:14:08.242 INFO 1481 --- [ main] s.c.a.AnnotationConfigApplicationContext : Refreshing org.springframework.context.annotation.AnnotationConfigApplicationContext@140e5a13: startup date [Tue Feb 16 00:14:08 CST 2016]; root of context hierarchy
2016-02-16 00:14:09.756 INFO 1481 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup
2016-02-16 00:14:09.763 INFO 1481 --- [ main] o.s.c.support.DefaultLifecycleProcessor : Starting beans in phase 0
2016-02-16 00:14:09.807 INFO 1481 --- [ main] o.s.c.support.DefaultLifecycleProcessor : Starting beans in phase 2147483647
2016-02-16 00:14:09.897 INFO 1481 --- [ main] com.codecraft.RedisdemoApplication : Started RedisdemoApplication in 2.215 seconds (JVM running for 2.589)
Message received: "Message 1, pool-1-thread-1"
Message received: "Message 2, pool-1-thread-1"
Message received: "Message 3, pool-1-thread-1"
Message received: "Message 4, pool-1-thread-1"
Message received: "Message 5, pool-1-thread-1"
Message received: "Message 6, pool-1-thread-1"
Message received: "Message 7, pool-1-thread-1"
Message received: "Message 8, pool-1-thread-1"
Message received: "Message 9, pool-1-thread-1"
Message received: "Message 10, pool-1-thread-1"

文档

redis的发布订阅功能

redis的发布订阅功能:序redis提供了简单的发布订阅功能,对于一些合适的场景(比如不要求消费者不在线时也能收到离线消息),比起专业的MQ来说,用起来更简单些。本文主要是记录下怎么在SpringBoot里头使用redis的发布订阅功能。定义生产者配置@Bean MyPublisher red
推荐度:
标签: 模式 功能 订阅
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top