溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

SpringBoot集成Redis如何使用RedisRepositories

發(fā)布時(shí)間:2022-03-15 14:47:40 來(lái)源:億速云 閱讀:370 作者:iii 欄目:開(kāi)發(fā)技術(shù)

這篇“SpringBoot集成Redis如何使用RedisRepositories”文章的知識(shí)點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來(lái)看看這篇“SpringBoot集成Redis如何使用RedisRepositories”文章吧。

    SpringBoot集成Redis

     1.添加redis依賴

    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-data-redis</artifactId>
    </dependency>
    <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-pool2</artifactId>
    </dependency>

    2.在application.properties中添加redis配置信息

    spring.redis.host=127.0.0.1
    # Redis服務(wù)器連接端口
    spring.redis.port=6379
    # Redis服務(wù)器連接密碼(默認(rèn)為空)
    spring.redis.password=
    # 連接池最大連接數(shù)(使用負(fù)值表示沒(méi)有限制)
    spring.redis.lettuce.pool.max-active=8
    # 連接池最大阻塞等待時(shí)間(使用負(fù)值表示沒(méi)有限制)
    spring.redis.lettuce.pool.max-wait=-1
    # 連接池中的最大空閑連接
    spring.redis.lettuce.pool.max-idle=8
    # 連接池中的最小空閑連接
    spring.redis.lettuce.pool.min-idle=0
    # 連接超時(shí)時(shí)間(毫秒)
    spring.redis.timeout=30000

    3.SpringBoot啟動(dòng)類中添加注解配置

    @EnableCaching
    @EnableRedisRepositories
    //注解開(kāi)啟使用RedisRepositories
    //CRUD操作將會(huì)操作redis中的數(shù)據(jù)
    @SpringBootApplication
    public class RedisApplication {
     
        public static void main(String[] args) {
            SpringApplication.run(RedisApplication.class, args);
        } 
    }

    4.創(chuàng)建實(shí)體類Entity

    @Data
    @RedisHash("user")
    //RedisHash非常重要
    //user表示在redis中新建user集合
    //之后所有的UserEntity的保存操作全部會(huì)保存在user這個(gè)集合中
    //保存時(shí)Key的格式為——user:id
    public class UserEntity{
        @Id
        private Long id; 
        private String name; 
        private Integer age; 
        private Date createTime = new Date();
    }

    5.創(chuàng)建Dao層&mdash;&mdash;數(shù)據(jù)操作層

    @Repository
    public interface UserDao extends CrudRepository<UserEntity,Long> {
    }

    6.創(chuàng)建Service層&mdash;&mdash;服務(wù)層

    @Service
    public class UserService {
     
        @Autowired
        private UserDao userDao;
     
    //因?yàn)槭褂昧薘edisRepositories,所以簡(jiǎn)單的crud將不用使用RedisTemplate
    //    @Autowired
    //    private RedisTemplate redisTemplate; 
     
        /**
         * 按user:id的方式存入redis
         * @param user
         */
        public void save(UserEntity user){
            //redisTemplate.opsForValue().set(new Random().nextDouble() + "",user); 
            userDao.save(user); 
        }
     
        /**
         * 根據(jù)key從redis中查找對(duì)應(yīng)value
         * @param id
         * @return
         */
        public UserEntity findOne(Long id){ 
            //UserEntity user = (UserEntity) redisTemplate.opsForValue().get(key); 
            UserEntity user = userDao.findById(id).get(); 
            return user;
        }
    }

    7.創(chuàng)建Controller層&mdash;&mdash;控制層

    @RestController
    @RequestMapping("user")
    public class UserController {
     
        @Autowired
        private UserService userService;
     
        /**
         * 保存到redis中
         * @return
         */
        @GetMapping("save")
        public String save(){
     
            UserEntity user = new UserEntity(); 
            user.setName(String.valueOf(new Random().nextInt(100000))); 
            user.setAge(new Random().nextInt(100000)); 
            userService.save(user); 
            System.out.println(user.toString()); 
            return "success";
        }
     
        /**
         * 根據(jù)key從redis中查找value
         * @param id
         * @return
         */
        @GetMapping("find/{id}")
        public String find(@PathVariable Long id){
           UserEntity user = userService.findOne(id);
     
            System.out.println(user);
            return "success";
        }
    }

    8.redis配置類

    @Configuration
    public class RedisConfig {
     
        @Bean
        public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) {
            RedisTemplate<String, Object> template = new RedisTemplate<String, Object>();
            template.setConnectionFactory(factory);
            Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
            ObjectMapper om = new ObjectMapper();
            om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
            om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
            jackson2JsonRedisSerializer.setObjectMapper(om);
            StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
            // key采用String的序列化方式
            template.setKeySerializer(stringRedisSerializer);
            // hash的key也采用String的序列化方式
            template.setHashKeySerializer(stringRedisSerializer);
            // value序列化方式采用jackson
            template.setValueSerializer(jackson2JsonRedisSerializer);
            // hash的value序列化方式采用jackson
            template.setHashValueSerializer(jackson2JsonRedisSerializer);
            template.afterPropertiesSet();
            return template;
        }
    }

    Redis中的結(jié)構(gòu)為

    SpringBoot集成Redis如何使用RedisRepositories

    redis封裝工具類

    @Component
    public class RedisUtils {
     
    	@Autowired
    	private RedisTemplate<String, Object> redisTemplate;
     
    	// =============================common============================
     
    	/**
    	 * 指定緩存失效時(shí)間
    	 *
    	 * @param key  鍵
    	 * @param time 時(shí)間(秒)
    	 * @return
    	 */
    	public boolean expire(String key, long time) {
    		try {
    			if (time > 0) {
    				redisTemplate.expire(key, time, TimeUnit.SECONDS);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 根據(jù)key 獲取過(guò)期時(shí)間
    	 *
    	 * @param key 鍵 不能為null
    	 * @return 時(shí)間(秒) 返回0代表為永久有效
    	 */
    	public long getExpire(String key) {
    		return redisTemplate.getExpire(key, TimeUnit.SECONDS);
    	}
     
    	/**
    	 * 判斷key是否存在
    	 *
    	 * @param key 鍵
    	 * @return true 存在 false不存在
    	 */
    	public boolean hasKey(String key) {
    		try {
    			return redisTemplate.hasKey(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 刪除緩存
    	 *
    	 * @param key 可以傳一個(gè)值 或多個(gè)
    	 */
    	@SuppressWarnings("unchecked")
    	public void del(String... key) {
    		if (key != null && key.length > 0) {
    			if (key.length == 1) {
    				redisTemplate.delete(key[0]);
    			} else {
    				redisTemplate.delete(CollectionUtils.arrayToList(key));
    			}
    		}
    	}
    	// ============================String=============================
     
    	/**
    	 * 普通緩存獲取
    	 *
    	 * @param key 鍵
    	 * @return 值
    	 */
    	public  Object get(String key) {
    		return key == null ? null : redisTemplate.opsForValue().get(key);
    	}
     
    	/**
    	 * 普通緩存放入
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return true成功 false失敗
    	 */
    	public boolean set(String key, Object value) {
    		try {
    			redisTemplate.opsForValue().set(key, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 普通緩存放入并設(shè)置時(shí)間
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @param time  時(shí)間(秒) time要大于0 如果time小于等于0 將設(shè)置無(wú)限期
    	 * @return true成功 false 失敗
    	 */
    	public boolean set(String key, Object value, long time) {
    		try {
    			if (time > 0) {
    				redisTemplate.opsForValue().set(key, value, time, TimeUnit.SECONDS);
    			} else {
    				set(key, value);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 遞增
    	 *
    	 * @param key   鍵
    	 * @param delta 要增加幾(大于0)
    	 * @return
    	 */
    	public long incr(String key, long delta) {
    		if (delta < 0) {
    			throw new RuntimeException("遞增因子必須大于0");
    		}
    		return redisTemplate.opsForValue().increment(key, delta);
    	}
     
    	/**
    	 * 遞減
    	 *
    	 * @param key   鍵
    	 * @param delta 要減少幾(小于0)
    	 * @return
    	 */
    	public long decr(String key, long delta) {
    		if (delta < 0) {
    			throw new RuntimeException("遞減因子必須大于0");
    		}
    		return redisTemplate.opsForValue().increment(key, -delta);
    	}
    	// ================================Map=================================
     
    	/**
    	 * HashGet
    	 *
    	 * @param key  鍵 不能為null
    	 * @param item 項(xiàng) 不能為null
    	 * @return 值
    	 */
    	public Object hget(String key, String item) {
    		return redisTemplate.opsForHash().get(key, item);
    	}
     
    	/**
    	 * 獲取hashKey對(duì)應(yīng)的所有鍵值
    	 *
    	 * @param key 鍵
    	 * @return 對(duì)應(yīng)的多個(gè)鍵值
    	 */
    	public Map<Object, Object> hmget(String key) {
    		return redisTemplate.opsForHash().entries(key);
    	}
     
    	/**
    	 * HashSet
    	 *
    	 * @param key 鍵
    	 * @param map 對(duì)應(yīng)多個(gè)鍵值
    	 * @return true 成功 false 失敗
    	 */
    	public boolean hmset(String key, Map<String, Object> map) {
    		try {
    			redisTemplate.opsForHash().putAll(key, map);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * HashSet 并設(shè)置時(shí)間
    	 *
    	 * @param key  鍵
    	 * @param map  對(duì)應(yīng)多個(gè)鍵值
    	 * @param time 時(shí)間(秒)
    	 * @return true成功 false失敗
    	 */
    	public boolean hmset(String key, Map<String, Object> map, long time) {
    		try {
    			redisTemplate.opsForHash().putAll(key, map);
    			if (time > 0) {
    				expire(key, time);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 向一張hash表中放入數(shù)據(jù),如果不存在將創(chuàng)建
    	 *
    	 * @param key   鍵
    	 * @param item  項(xiàng)
    	 * @param value 值
    	 * @return true 成功 false失敗
    	 */
    	public boolean hset(String key, String item, Object value) {
    		try {
    			redisTemplate.opsForHash().put(key, item, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 向一張hash表中放入數(shù)據(jù),如果不存在將創(chuàng)建
    	 *
    	 * @param key   鍵
    	 * @param item  項(xiàng)
    	 * @param value 值
    	 * @param time  時(shí)間(秒) 注意:如果已存在的hash表有時(shí)間,這里將會(huì)替換原有的時(shí)間
    	 * @return true 成功 false失敗
    	 */
    	public boolean hset(String key, String item, Object value, long time) {
    		try {
    			redisTemplate.opsForHash().put(key, item, value);
    			if (time > 0) {
    				expire(key, time);
    			}
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 刪除hash表中的值
    	 *
    	 * @param key  鍵 不能為null
    	 * @param item 項(xiàng) 可以使多個(gè) 不能為null
    	 */
    	public void hdel(String key, Object... item) {
    		redisTemplate.opsForHash().delete(key, item);
    	}
     
    	/**
    	 * 判斷hash表中是否有該項(xiàng)的值
    	 *
    	 * @param key  鍵 不能為null
    	 * @param item 項(xiàng) 不能為null
    	 * @return true 存在 false不存在
    	 */
    	public boolean hHasKey(String key, String item) {
    		return redisTemplate.opsForHash().hasKey(key, item);
    	}
     
    	/**
    	 * hash遞增 如果不存在,就會(huì)創(chuàng)建一個(gè) 并把新增后的值返回
    	 *
    	 * @param key  鍵
    	 * @param item 項(xiàng)
    	 * @param by   要增加幾(大于0)
    	 * @return
    	 */
    	public double hincr(String key, String item, double by) {
    		return redisTemplate.opsForHash().increment(key, item, by);
    	}
     
    	/**
    	 * hash遞減
    	 *
    	 * @param key  鍵
    	 * @param item 項(xiàng)
    	 * @param by   要減少記(小于0)
    	 * @return
    	 */
    	public double hdecr(String key, String item, double by) {
    		return redisTemplate.opsForHash().increment(key, item, -by);
    	}
    	// ============================set=============================
     
    	/**
    	 * 根據(jù)key獲取Set中的所有值
    	 *
    	 * @param key 鍵
    	 * @return
    	 */
    	public Set<Object> sGet(String key) {
    		try {
    			return redisTemplate.opsForSet().members(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return null;
    		}
    	}
     
    	/**
    	 * 根據(jù)value從一個(gè)set中查詢,是否存在
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return true 存在 false不存在
    	 */
    	public boolean sHasKey(String key, Object value) {
    		try {
    			return redisTemplate.opsForSet().isMember(key, value);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將數(shù)據(jù)放入set緩存
    	 *
    	 * @param key    鍵
    	 * @param values 值 可以是多個(gè)
    	 * @return 成功個(gè)數(shù)
    	 */
    	public long sSet(String key, Object... values) {
    		try {
    			return redisTemplate.opsForSet().add(key, values);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 將set數(shù)據(jù)放入緩存
    	 *
    	 * @param key    鍵
    	 * @param time   時(shí)間(秒)
    	 * @param values 值 可以是多個(gè)
    	 * @return 成功個(gè)數(shù)
    	 */
    	public long sSetAndTime(String key, long time, Object... values) {
    		try {
    			Long count = redisTemplate.opsForSet().add(key, values);
    			if (time > 0)
    				expire(key, time);
    			return count;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 獲取set緩存的長(zhǎng)度
    	 *
    	 * @param key 鍵
    	 * @return
    	 */
    	public long sGetSetSize(String key) {
    		try {
    			return redisTemplate.opsForSet().size(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 移除值為value的
    	 *
    	 * @param key    鍵
    	 * @param values 值 可以是多個(gè)
    	 * @return 移除的個(gè)數(shù)
    	 */
    	public long setRemove(String key, Object... values) {
    		try {
    			Long count = redisTemplate.opsForSet().remove(key, values);
    			return count;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
    	// ===============================list=================================
     
    	/**
    	 * 獲取list緩存的內(nèi)容
    	 *
    	 * @param key   鍵
    	 * @param start 開(kāi)始
    	 * @param end   結(jié)束 0 到 -1代表所有值
    	 * @return
    	 */
    	public List<Object> lGet(String key, long start, long end) {
    		try {
    			return redisTemplate.opsForList().range(key, start, end);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return null;
    		}
    	}
     
    	/**
    	 * 獲取list緩存的長(zhǎng)度
    	 *
    	 * @param key 鍵
    	 * @return
    	 */
    	public long lGetListSize(String key) {
    		try {
    			return redisTemplate.opsForList().size(key);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
     
    	/**
    	 * 通過(guò)索引 獲取list中的值
    	 *
    	 * @param key   鍵
    	 * @param index 索引 index>=0時(shí), 0 表頭,1 第二個(gè)元素,依次類推;index<0時(shí),-1,表尾,-2倒數(shù)第二個(gè)元素,依次類推
    	 * @return
    	 */
    	public Object lGetIndex(String key, long index) {
    		try {
    			return redisTemplate.opsForList().index(key, index);
    		} catch (Exception e) {
    			e.printStackTrace();
    			return null;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return
    	 */
    	public boolean lSet(String key, Object value) {
    		try {
    			redisTemplate.opsForList().rightPush(key, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @param time  時(shí)間(秒)
    	 * @return
    	 */
    	public boolean lSet(String key, Object value, long time) {
    		try {
    			redisTemplate.opsForList().rightPush(key, value);
    			if (time > 0)
    				expire(key, time);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @return
    	 */
    	public boolean lSet(String key, List<Object> value) {
    		try {
    			redisTemplate.opsForList().rightPushAll(key, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 將list放入緩存
    	 *
    	 * @param key   鍵
    	 * @param value 值
    	 * @param time  時(shí)間(秒)
    	 * @return
    	 */
    	public boolean lSet(String key, List<Object> value, long time) {
    		try {
    			redisTemplate.opsForList().rightPushAll(key, value);
    			if (time > 0)
    				expire(key, time);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 根據(jù)索引修改list中的某條數(shù)據(jù)
    	 *
    	 * @param key   鍵
    	 * @param index 索引
    	 * @param value 值
    	 * @return
    	 */
    	public boolean lUpdateIndex(String key, long index, Object value) {
    		try {
    			redisTemplate.opsForList().set(key, index, value);
    			return true;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return false;
    		}
    	}
     
    	/**
    	 * 移除N個(gè)值為value
    	 *
    	 * @param key   鍵
    	 * @param count 移除多少個(gè)
    	 * @param value 值
    	 * @return 移除的個(gè)數(shù)
    	 */
    	public long lRemove(String key, long count, Object value) {
    		try {
    			Long remove = redisTemplate.opsForList().remove(key, count, value);
    			return remove;
    		} catch (Exception e) {
    			e.printStackTrace();
    			return 0;
    		}
    	}
    }

    以上就是關(guān)于“SpringBoot集成Redis如何使用RedisRepositories”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對(duì)大家有幫助,若想了解更多相關(guān)的知識(shí)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

    向AI問(wèn)一下細(xì)節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

    AI