当前位置:   article > 正文

SpringBoot 集成 redis 发布订阅_springboot整合redis 发布订阅

springboot整合redis 发布订阅
 redis 配置类
  1. import com.fasterxml.jackson.annotation.JsonAutoDetect;
  2. import com.fasterxml.jackson.annotation.PropertyAccessor;
  3. import com.fasterxml.jackson.databind.ObjectMapper;
  4. import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
  5. import org.springframework.boot.autoconfigure.AutoConfigureBefore;
  6. import org.springframework.boot.autoconfigure.data.redis.RedisAutoConfiguration;
  7. import org.springframework.cache.annotation.CachingConfigurerSupport;
  8. import org.springframework.cache.annotation.EnableCaching;
  9. import org.springframework.context.annotation.Bean;
  10. import org.springframework.context.annotation.Configuration;
  11. import org.springframework.data.redis.connection.RedisConnectionFactory;
  12. import org.springframework.data.redis.core.RedisTemplate;
  13. import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
  14. import org.springframework.data.redis.serializer.RedisSerializer;
  15. import org.springframework.data.redis.serializer.StringRedisSerializer;
  16. @Configuration
  17. @EnableCaching
  18. @AutoConfigureBefore(RedisAutoConfiguration.class)
  19. public class RedisConfiguration extends CachingConfigurerSupport {
  20. /**
  21. *
  22. * 对 redis 操作做一些预处理
  23. *
  24. */
  25. @Bean
  26. public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
  27. RedisSerializer<Object> serializer = redisSerializer();
  28. RedisTemplate<String, Object> redisTemplate = new RedisTemplate<>();
  29. redisTemplate.setConnectionFactory(redisConnectionFactory);
  30. redisTemplate.setKeySerializer(new StringRedisSerializer());
  31. redisTemplate.setValueSerializer(serializer);
  32. redisTemplate.setHashKeySerializer(new StringRedisSerializer());
  33. redisTemplate.setHashValueSerializer(serializer);
  34. redisTemplate.afterPropertiesSet();
  35. return redisTemplate;
  36. }
  37. @Bean
  38. public RedisSerializer<Object> redisSerializer() {
  39. //创建JSON序列化器
  40. Jackson2JsonRedisSerializer<Object> serializer = new Jackson2JsonRedisSerializer<>(Object.class);
  41. ObjectMapper objectMapper = new ObjectMapper();
  42. objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
  43. //必须设置,否则无法将JSON转化为对象,会转化成Map类型
  44. objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);
  45. serializer.setObjectMapper(objectMapper);
  46. return serializer;
  47. }
  48. // @Bean
  49. // public RedisCacheManager redisCacheManager(RedisConnectionFactory redisConnectionFactory) {
  50. // RedisCacheWriter redisCacheWriter = RedisCacheWriter.nonLockingRedisCacheWriter(redisConnectionFactory);
  51. // //设置Redis缓存有效期为1天
  52. // RedisCacheConfiguration redisCacheConfiguration = RedisCacheConfiguration.defaultCacheConfig()
  53. // .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer())).entryTtl(Duration.ofDays(-1));
  54. // return new RedisCacheManager(redisCacheWriter, redisCacheConfiguration);
  55. // }
  56. }
redis-topic配置
  1. cloud:
  2. redis:
  3. topic-list:
  4. - name: Custom
  5. listener-class: com.huxiaosu.cloud.system.listener.CustomListener
  1. import lombok.Data;
  2. import org.springframework.boot.context.properties.ConfigurationProperties;
  3. import org.springframework.stereotype.Component;
  4. import java.io.Serializable;
  5. import java.util.List;
  6. @Data
  7. @Component
  8. @ConfigurationProperties(ScanMenuConfig.PREFIX)
  9. public class CloudRedisProperties implements Serializable {
  10. public static final String PREFIX = "cloud.redis";
  11. private List<Topic> topicList;
  12. @Data
  13. public static class Topic{
  14. private String name;
  15. private String listenerClass;
  16. }
  17. }
  1. import cn.hutool.core.collection.CollUtil;
  2. import com.fasterxml.jackson.annotation.JsonAutoDetect;
  3. import com.fasterxml.jackson.annotation.PropertyAccessor;
  4. import com.fasterxml.jackson.databind.ObjectMapper;
  5. import com.fasterxml.jackson.databind.jsontype.impl.LaissezFaireSubTypeValidator;
  6. import lombok.extern.slf4j.Slf4j;
  7. import org.springframework.beans.factory.annotation.Autowired;
  8. import org.springframework.context.annotation.Bean;
  9. import org.springframework.context.annotation.Configuration;
  10. import org.springframework.core.task.TaskExecutor;
  11. import org.springframework.data.redis.connection.RedisConnectionFactory;
  12. import org.springframework.data.redis.listener.PatternTopic;
  13. import org.springframework.data.redis.listener.RedisMessageListenerContainer;
  14. import org.springframework.data.redis.listener.adapter.MessageListenerAdapter;
  15. import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
  16. import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
  17. import java.util.List;
  18. @Slf4j
  19. @Configuration
  20. public class RedisPubSubConfig {
  21. @Autowired
  22. private CloudRedisProperties cloudRedisProperties;
  23. @Bean
  24. public RedisMessageListenerContainer container(RedisConnectionFactory redisConnectionFactory) {
  25. RedisMessageListenerContainer redisMessageListenerContainer = new RedisMessageListenerContainer();
  26. redisMessageListenerContainer.setConnectionFactory(redisConnectionFactory);
  27. // 订阅多个频道
  28. List<CloudRedisProperties.Topic> topicList = cloudRedisProperties.getTopicList();
  29. if(CollUtil.isEmpty(topicList)) {
  30. return redisMessageListenerContainer;
  31. }
  32. for(CloudRedisProperties.Topic topic: topicList){
  33. try {
  34. Class<?> aClass = Class.forName(topic.getListenerClass());
  35. // onMessage 为 listenerClass 中处理消息的方法
  36. MessageListenerAdapter getMessage = new MessageListenerAdapter(aClass.newInstance(), "onMessage");
  37. redisMessageListenerContainer.addMessageListener(getMessage, new PatternTopic(topic.getName()));
  38. log.info("add listener [{}] on topic [{}]",topic.getListenerClass(),topic.getName());
  39. }catch (Exception e){
  40. log.error("add redis listener error",e);
  41. }
  42. }
  43. //序列化对象(特别注意:发布的时候需要设置序列化;订阅方也需要设置序列化)
  44. Jackson2JsonRedisSerializer seria = new Jackson2JsonRedisSerializer(Object.class);
  45. ObjectMapper objectMapper = new ObjectMapper();
  46. objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
  47. objectMapper.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL);
  48. seria.setObjectMapper(objectMapper);
  49. redisMessageListenerContainer.setTopicSerializer(seria);
  50. redisMessageListenerContainer.setTaskExecutor(executor());
  51. return redisMessageListenerContainer;
  52. }
  53. @Bean
  54. public TaskExecutor executor() {
  55. ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
  56. executor.setCorePoolSize(Runtime.getRuntime().availableProcessors());
  57. executor.setMaxPoolSize(Runtime.getRuntime().availableProcessors() * 2);
  58. executor.setQueueCapacity(100);
  59. executor.initialize();
  60. return executor;
  61. }
  62. }
  1. import lombok.extern.slf4j.Slf4j;
  2. import org.jetbrains.annotations.NotNull;
  3. import org.springframework.data.redis.connection.Message;
  4. import org.springframework.data.redis.connection.MessageListener;
  5. import java.util.ArrayList;
  6. import java.util.HashMap;
  7. import java.util.List;
  8. import java.util.Map;
  9. @Slf4j
  10. public class CustomListener implements MessageListener {
  11. @Override
  12. public void onMessage(@NotNull Message message, byte[] topic) {
  13. log.info("CustomListener ... {}",message.toString);
  14. log.info("topic ... {}",new String(topic));
  15. }
  16. }

需要注意的是 CustomListener 是通过newInstance创建的,不能直接注入 Bean 对象;如果想要使用 SpringBean 需要使用 SpringContextHolder 来获取 Bean 对象


                
声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号