zoukankan      html  css  js  c++  java
  • Redis在springboot项目的使用

    一、在pom.xml配置redis依赖

    <!-- redis客户端代码 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <!-- json工具 -->
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>fastjson</artifactId>
        <version>1.2.49</version>
    </dependency>
    <!-- redis需要用到这个依赖,否则报错 -->
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-pool2</artifactId>
    </dependency>
    

    二、在common包中自定义一个RedisService以及其实现类

    Redis的方法比较复杂,可以将经常使用的抽取成方法,形成工具类,方便调用(使用接口加实现类的方式);调用redis时,如下

    @Autowired
    private RedisService redisService;

    RedisService.java接口

    package cn.kooun.common.redis;
    
    import cn.kooun.common.redis.entity.MessageCommon;
    
    /**
     * redis service
     */
    public interface RedisService {
    	/**
    	 * 添加
    	 * 
    	 * @param key
    	 * @param value
    	 * @return
    	 */
    	boolean set(final String key, Object value);
    	/**
    	 * 添加 有生命周期
    	 * 
    	 * @param key
    	 * @param value
    	 * @param expireTime
    	 * @return
    	 */
    	boolean set(final String key, Object value, Long expireTime);
    	/**
    	 * 获取
    	 * 
    	 * @param key
    	 * @return
    	 */
    	Object get(String key);
    	/**
    	 * 删除
    	 * 
    	 * @param key
    	 */
    	void delete(final String key);
    	/**
    	 * 	发送广播消息
    	 * @param topic
    	 * @param body
    	 */
    	void sendTopic(String topic, MessageCommon body);
    }
    

    实现类RedisServiceImpl.java

    package cn.kooun.common.redis.impl;
    
    import java.util.concurrent.TimeUnit;
    
    import javax.annotation.Resource;
    
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.data.redis.core.ValueOperations;
    import org.springframework.stereotype.Service;
    
    import com.alibaba.fastjson.JSON;
    
    import cn.kooun.common.redis.RedisService;
    import cn.kooun.common.redis.entity.MessageCommon;
    
    /**
     * redis工具类
     */
    @Service
    public class RedisServiceImpl implements RedisService{
    	@Resource
        private RedisTemplate<String, Object> redisTemplate;
    	
    	/**
    	 * 添加
    	 * 
    	 * @param key
    	 * @param value
    	 * @return
    	 */
    	@SuppressWarnings("all")
    	@Override
        public boolean set(final String key, Object value) {
            boolean result = false;
        	ValueOperations<String, Object> operations = redisTemplate.opsForValue();
        	operations.set(key, value);
        	return true;
        }
    	/**
    	 * 添加带生命周期
    	 */
    	@Override
        public boolean set(final String key, Object value, Long expireTime) {
            boolean result = false;
            ValueOperations<String, Object> operations = redisTemplate.opsForValue();
            operations.set(key, value, expireTime, TimeUnit.SECONDS);
            result = true;
            return result;
        }
    	/**
    	 * 获取
    	 */
    	@Override
    	public Object get(final String key) {
    		ValueOperations<String, Object> operations = redisTemplate.opsForValue();
    		return operations.get(key);
    	}
    	/**
    	 * 删除
    	 */
    	@Override
    	@SuppressWarnings("all")
        public void delete(final String key) {
    		redisTemplate.delete(key);
        }
    	
    	/**
    	 * 	发送广播消息
    	 */
    	@Override
    	public void sendTopic(String topic,MessageCommon body) {
    		body.setConsumerTopic(topic);
    		redisTemplate.convertAndSend(topic,JSON.toJSONString(body));
    	}
    }
    

    redis广播消息体实体类MessageCommon

    package cn.kooun.common.redis.entity;
    
    /**
     *  redis广播消息体实体类
     * @author chenWei
     * @date 2019年11月7日 上午10:47:08
     */
    public class MessageCommon {
    	/**对方监听器执行回调的方法名*/
    	private String method;
    	/**消息体*/
    	private String body;
    	/**消息生产者的消费主题,便于回复消息*/
    	private String producerTopic;
    	/**消费者消费的主题*/
    	private String consumerTopic;
    	
    	public MessageCommon(String method, String body) {
    		this.method = method;
    		this.body = body;
    	}
    	
    	public String getMethod() {
    		return method;
    	}
    	public void setMethod(String method) {
    		this.method = method;
    	}
    	public String getBody() {
    		return body;
    	}
    	public void setBody(String body) {
    		this.body = body;
    	}
    
    	public String getProducerTopic() {
    		return producerTopic;
    	}
    
    	public void setProducerTopic(String producerTopic) {
    		this.producerTopic = producerTopic;
    	}
    
    	public String getConsumerTopic() {
    		return consumerTopic;
    	}
    
    	public void setConsumerTopic(String consumerTopic) {
    		this.consumerTopic = consumerTopic;
    	}
    
    	@Override
    	public String toString() {
    		return "MessageCommon [method=" + method + ", body=" + body + ", producerTopic=" + producerTopic
    				+ ", consumerTopic=" + consumerTopic + "]";
    	}
    	
    }
    

    三、redis可视化工具乱码(springboot中添加一个类)

    package cn.kooun.common.redis;
    
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.data.redis.connection.RedisConnectionFactory;
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.data.redis.serializer.GenericJackson2JsonRedisSerializer;
    import org.springframework.data.redis.serializer.StringRedisSerializer;
    
    /**
     * 	解决redis可视化工具乱码问题
     * @author HuangJingNa
     * @date 2019年12月21日 下午3:15:19
     *
     */
    @Configuration
    public class RedisConfigBean {
    
        /**
         * redis 防止key value 前缀乱码.
         *
         * @param factory redis连接 factory
         * @return redisTemplate
         */
        @Bean(name = "redisTemplate")
        public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
            RedisTemplate<String, Object> template = new RedisTemplate<>();
            template.setConnectionFactory(factory);
            template.setKeySerializer(new StringRedisSerializer());
            template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
            template.setHashKeySerializer(new GenericJackson2JsonRedisSerializer());
            template.setHashValueSerializer(new GenericJackson2JsonRedisSerializer());
            template.afterPropertiesSet();
            return template;
        }
    
    }
    

    package cn.kooun.core.config;
    
    import java.lang.reflect.Method;
    
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.cache.annotation.CachingConfigurerSupport;
    import org.springframework.cache.annotation.EnableCaching;
    import org.springframework.cache.interceptor.KeyGenerator;
    import org.springframework.context.annotation.Bean;
    import org.springframework.context.annotation.Configuration;
    import org.springframework.data.redis.connection.RedisConnectionFactory;
    import org.springframework.data.redis.core.RedisTemplate;
    import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
    import org.springframework.data.redis.serializer.StringRedisSerializer;
    
    import com.fasterxml.jackson.annotation.JsonAutoDetect;
    import com.fasterxml.jackson.annotation.PropertyAccessor;
    import com.fasterxml.jackson.databind.ObjectMapper;
    /**
     * redis配置
     * 
     * @author chenWei
     * @date 2019年9月12日 上午11:00:27
     *
     */
    @Configuration
    @EnableCaching
    //自动注入自定义对象到参数列表
    @SuppressWarnings("all")
    public class RedisConfig  extends CachingConfigurerSupport {
    	
    	/**
    	 * key的生成策略
    	 */
    	@Bean
        public KeyGenerator keyGenerator() {
            return new KeyGenerator() {
                @Override
                public Object generate(Object target, Method method, Object... params) {
                    StringBuilder sb = new StringBuilder();
                    sb.append(target.getClass().getName());
                    sb.append(method.getName());
                    for (Object obj : params) {
                        sb.append(obj.toString());
                    }
                    return sb;
                }
    
            };
        }
        /**
         * RedisTemplate配置
         * @author chenwei
         * @date 2019年7月2日 上午10:31:44
         * @param factory
         * @return
         */
        @Bean
        public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
        	RedisTemplate<String, Object> template = new RedisTemplate<>();
            // 配置连接工厂
            template.setConnectionFactory(factory);
    
            //使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值(默认使用JDK的序列化方式)
            Jackson2JsonRedisSerializer jacksonSeial = new Jackson2JsonRedisSerializer(Object.class);
    
            ObjectMapper om = new ObjectMapper();
            // 指定要序列化的域,field,get和set,以及修饰符范围,ANY是都有包括private和public
            om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
            // 指定序列化输入的类型,类必须是非final修饰的,final修饰的类,比如String,Integer等会跑出异常
            om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
            jacksonSeial.setObjectMapper(om);
    
            // 值采用json序列化
            template.setValueSerializer(jacksonSeial);
            //使用StringRedisSerializer来序列化和反序列化redis的key值
            template.setKeySerializer(new StringRedisSerializer());
    
            // 设置hash key 和value序列化模式
            template.setHashKeySerializer(new StringRedisSerializer());
            template.setHashValueSerializer(jacksonSeial);
            template.afterPropertiesSet();
    
            return template;
        }
        
        
    }
    
  • 相关阅读:
    pyspark使用及原理
    谷歌地图聚合点使用(GoogleMaps MarkerCluster)
    struts2升级到2.5的配置
    二进制反码补码
    进制转换
    JAVA基础第一章
    TypeError: unhashable type: 'list' 如何解决?
    剪辑模板
    Mysql三天入门(三) 数据库设计的三范式
    Mysql三天入门(三) DBA命令
  • 原文地址:https://www.cnblogs.com/nadou/p/14003652.html
Copyright © 2011-2022 走看看