美文网首页
Springboot 技术整合--笔记3--Redis

Springboot 技术整合--笔记3--Redis

作者: 牵手生活 | 来源:发表于2019-05-03 11:56 被阅读0次

    前言

    继续Springboot5 开发常用技术整合--笔记2--mybatis及pageHelper

    NoSQL之 --Redis学习笔记
    Springboot使用RedisTemplate优雅地操作redis

    涉及到的知识点

    • pom.xml中引入需要的相关依赖
    • object转json,json转object(工具类)
    • StringRedisTemplate 操作redis及其封装RedisOperator
    • redis桌面管理工具RedisDesktopManager

    pom.xml中引入需要的相关依赖

            <!-- 引入 redis 依赖 -->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-data-redis</artifactId>
            </dependency>
    

    资源文件中对redis进行配置

    
    ############################################################
    #
    # REDIS 配置
    #
    ############################################################
    # Redis数据库索引
    spring.redis.database=1
    # Redis数据库地址
    spring.redis.host=39.97.***.***
    # Redis服务器链接端口
    spring.redis.port=6379
    # Redis服务器链接密码(默认为空)
    spring.redis.password=
    # 连接池最大连接数(使用负值表示没用限制)
    
    #spring.redis.pool.max-active=1000 //在springboot版本1.4之后pool熟悉被封装到了类jedis中
    spring.redis.jedis.pool.max-active=1000
    # 连接池最大阻塞等待时间(使用负值表示没用限制)
    #spring.redis.pool.max-wait=-1
    #spring.redis.jedis.pool.max-wait=-1
    spring.redis.jedis.pool.max-wait=-1ms
    # 连接池中的最大空闲链接
    spring.redis.jedis.pool.max-idle=10
    #连接池中的最小空闲链接
    spring.redis.jedis.pool.min-idle=2
    #链接超时时间(毫秒)
    #spring.redis.timeout=0 //不知道为何设置为0,会报错
    spring.redis.timeout=100ms
    
    

    封装JsonUtils.java(类似Android的 new Gson().toJson(object))

    public class JsonUtils {
    
        // 定义jackson对象
        private static final ObjectMapper MAPPER = new ObjectMapper();
    
        /**
         * 将对象转换成json字符串。
         * <p>Title: pojoToJson</p>
         * <p>Description: </p>
         * @param data
         * @return
         */
        public static String objectToJson(Object data) {
            try {
                String string = MAPPER.writeValueAsString(data);
                return string;
            } catch (JsonProcessingException e) {
                e.printStackTrace();
            }
            return null;
        }
        
        /**
         * 将json结果集转化为对象
         * 
         * @param jsonData json数据
         * @param clazz 对象中的object类型
         * @return
         */
        public static <T> T jsonToPojo(String jsonData, Class<T> beanType) {
            try {
                T t = MAPPER.readValue(jsonData, beanType);
                return t;
            } catch (Exception e) {
                e.printStackTrace();
            }
            return null;
        }
        
        /**
         * 将json数据转换成pojo对象list
         * <p>Title: jsonToList</p>
         * <p>Description: </p>
         * @param jsonData
         * @param beanType
         * @return
         */
        public static <T>List<T> jsonToList(String jsonData, Class<T> beanType) {
            JavaType javaType = MAPPER.getTypeFactory().constructParametricType(List.class, beanType);
            try {
                List<T> list = MAPPER.readValue(jsonData, javaType);
                return list;
            } catch (Exception e) {
                e.printStackTrace();
            }
            
            return null;
        }
        
    }
    
    

    封装RedisOperator.java使用redisTemplate的操作实现类

    @Component
    public class RedisOperator {
        
    //  @Autowired
    //    private RedisTemplate<String, Object> redisTemplate;
        
        @Autowired
        private StringRedisTemplate redisTemplate;
        
        // Key(键),简单的key-value操作
    
        /**
         * 实现命令:TTL key,以秒为单位,返回给定 key的剩余生存时间(TTL, time to live)。
         * 
         * @param key
         * @return
         */
        public long ttl(String key) {
            return redisTemplate.getExpire(key);
        }
        
        /**
         * 实现命令:expire 设置过期时间,单位秒
         * 
         * @param key
         * @return
         */
        public void expire(String key, long timeout) {
            redisTemplate.expire(key, timeout, TimeUnit.SECONDS);
        }
        
        /**
         * 实现命令:INCR key,增加key一次
         * 
         * @param key
         * @return
         */
        public long incr(String key, long delta) {
            return redisTemplate.opsForValue().increment(key, delta);
        }
    
        /**
         * 实现命令:KEYS pattern,查找所有符合给定模式 pattern的 key
         */
        public Set<String> keys(String pattern) {
            return redisTemplate.keys(pattern);
        }
    
        /**
         * 实现命令:DEL key,删除一个key
         * 
         * @param key
         */
        public void del(String key) {
            redisTemplate.delete(key);
        }
    
        // String(字符串)
    
        /**
         * 实现命令:SET key value,设置一个key-value(将字符串值 value关联到 key)
         * 
         * @param key
         * @param value
         */
        public void set(String key, String value) {
            redisTemplate.opsForValue().set(key, value);
        }
    
        /**
         * 实现命令:SET key value EX seconds,设置key-value和超时时间(秒)
         * 
         * @param key
         * @param value
         * @param timeout
         *            (以秒为单位)
         */
        public void set(String key, String value, long timeout) {
            redisTemplate.opsForValue().set(key, value, timeout, TimeUnit.SECONDS);
        }
    
        /**
         * 实现命令:GET key,返回 key所关联的字符串值。
         * 
         * @param key
         * @return value
         */
        public String get(String key) {
            return (String)redisTemplate.opsForValue().get(key);
        }
    
        // Hash(哈希表)
    
        /**
         * 实现命令:HSET key field value,将哈希表 key中的域 field的值设为 value
         * 
         * @param key
         * @param field
         * @param value
         */
        public void hset(String key, String field, Object value) {
            redisTemplate.opsForHash().put(key, field, value);
        }
    
        /**
         * 实现命令:HGET key field,返回哈希表 key中给定域 field的值
         * 
         * @param key
         * @param field
         * @return
         */
        public String hget(String key, String field) {
            return (String) redisTemplate.opsForHash().get(key, field);
        }
    
        /**
         * 实现命令:HDEL key field [field ...],删除哈希表 key 中的一个或多个指定域,不存在的域将被忽略。
         * 
         * @param key
         * @param fields
         */
        public void hdel(String key, Object... fields) {
            redisTemplate.opsForHash().delete(key, fields);
        }
    
        /**
         * 实现命令:HGETALL key,返回哈希表 key中,所有的域和值。
         * 
         * @param key
         * @return
         */
        public Map<Object, Object> hgetall(String key) {
            return redisTemplate.opsForHash().entries(key);
        }
    
        // List(列表)
    
        /**
         * 实现命令:LPUSH key value,将一个值 value插入到列表 key的表头
         * 
         * @param key
         * @param value
         * @return 执行 LPUSH命令后,列表的长度。
         */
        public long lpush(String key, String value) {
            return redisTemplate.opsForList().leftPush(key, value);
        }
    
        /**
         * 实现命令:LPOP key,移除并返回列表 key的头元素。
         * 
         * @param key
         * @return 列表key的头元素。
         */
        public String lpop(String key) {
            return (String)redisTemplate.opsForList().leftPop(key);
        }
    
        /**
         * 实现命令:RPUSH key value,将一个值 value插入到列表 key的表尾(最右边)。
         * 
         * @param key
         * @param value
         * @return 执行 LPUSH命令后,列表的长度。
         */
        public long rpush(String key, String value) {
            return redisTemplate.opsForList().rightPush(key, value);
        }
    
    }
    

    插件RedisController.java

    
    @RestController
    @RequestMapping("redis")
    public class RedisController { 
        
        @Autowired
        private StringRedisTemplate strRedis;
        
        @Autowired
        private RedisOperator redis;  //Redis的操作类
        
        @RequestMapping("/test")
        public IYounghareJSONResult test() {  //使用StringRedisTemplate操作
    
            //设置一个字符串到redis
            strRedis.opsForValue().set("imooc-cache", "hello 慕课网~~~~~~");
    
            //设置一个user对象的到redis
            SysUser user = new SysUser();
            user.setId("100111");
            user.setUsername("imooc");
            user.setPassword("abc123");
            user.setIsDelete(0);
            user.setRegistTime(new Date());
            strRedis.opsForValue().set("json:user", JsonUtils.objectToJson(user));  //存入到redis
    
            //获取值
            SysUser jsonUser = JsonUtils.jsonToPojo(strRedis.opsForValue().get("json:user"), SysUser.class);  //redis取出对象
    
    
            
            return IYounghareJSONResult.ok(jsonUser);  //返回
        }
        
        @RequestMapping("/getJsonList")
        public IYounghareJSONResult getJsonList() {  //使用RedisOperator工具类操作
            
            User user = new User();
            user.setAge(18);
            user.setName("慕课网");
            user.setPassword("123456");
            user.setBirthday(new Date());
            
            User u1 = new User();
            u1.setAge(19);
            u1.setName("imooc");
            u1.setPassword("123456");
            u1.setBirthday(new Date());
            
            User u2 = new User();
            u2.setAge(17);
            u2.setName("hello imooc");
            u2.setPassword("123456");
            u2.setBirthday(new Date());
            
            List<User> userList = new ArrayList<>();
            userList.add(user);
            userList.add(u1);
            userList.add(u2);
            
            redis.set("json:info:userlist", JsonUtils.objectToJson(userList), 2000);
            
            String userListJson = redis.get("json:info:userlist");
            List<User> userListBorn = JsonUtils.jsonToList(userListJson, User.class);
            
            return IYounghareJSONResult.ok(userListBorn);
        }
    }
    

    运行测试

    http://localhost:8080/redis/test
    
    http://localhost:8080/redis/getJsonList
    
    redis-test结果 用Redis destop Manager查看
    image.png

    注意“:”的使用是为了层级的区分

    文章收集

    springboot+redis单点登录session共享

    相关文章

      网友评论

          本文标题:Springboot 技术整合--笔记3--Redis

          本文链接:https://www.haomeiwen.com/subject/vymanqtx.html