0


Springboot整合redis

文章目录

redis简介

Redis是一个开源的内存数据结构存储数据库,用作数据库,缓存等。提供了字符串,散列,列表,集合等数据结构。常用的场景有分布式session共享,缓存数据,临时存储如购物车等。

redis常用的命令

set get

set key value

在这里插入图片描述

setnx

setnx key value :
将 key 的值设为 value ,当且仅当 key 不存在。
若给定的 key 已经存在,则 SETNX 不做任何动作。

127.0.0.1:6379>set k1 v1
OK
127.0.0.1:6379>127.0.0.1:6379> setnx k1 v2
(integer)0127.0.0.1:6379>set k2 v2
OK
127.0.0.1:6379>

这里就不在多介绍,详细参考官网命令。

springboot中使用redis

引入依赖

<!--添加redis依赖--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-redis</artifactId><version>1.4.7.RELEASE</version></dependency><!--分布式session--><dependency><groupId>org.springframework.session</groupId><artifactId>spring-session-data-redis</artifactId><version>2.3.1.RELEASE</version></dependency>

配置redis

#配置redisredis:host: redis服务器地址
    database:0#配置数据库0port:6379#端口#password:#配置连接池jedis:pool:max-active:8max-idle:8min-idle:0max-wait:-1#ms

redis服务类接口

/**
 * 定义访问redis的接口类
 *
 */publicinterfaceRedisService{/**
     * 保存key value
     * @param key
     * @param value
     */voidsaveKeyValue(String key,Object value);/**
     * 保存key value
     * @param key
     * @param value
     */voidsaveKeyValue(String key,Object value,int expiration);/**
     * 根据key获取value
     * @param key
     * @return
     */StringgetValueByKey(String key);/**
     * 根据key删除缓存
     * @param key
     */voiddelete(String key);/**
     * 清空所有缓存
     */voidflushdb();}

redis服务实现类

/**
 * redis 实现类
 */@ServicepublicclassRedisServiceImplimplementsRedisService{@AutowiredRedisTemplate redisTemplate;/**
     * 保存key value
     * @param key
     * @param value
     */@OverridepublicvoidsaveKeyValue(String key,Object value){
        redisTemplate.opsForValue().set(key, value);}/**
     * 设置过期时间
     * @param key
     * @param value
     * @param expiration 过期时间
     */@OverridepublicvoidsaveKeyValue(String key,Object value,int expiration){
        redisTemplate.opsForValue().set(key, value);
        redisTemplate.expire(key, expiration,TimeUnit.MINUTES);}/**
     * 根据key获取value
     * @param key
     * @return
     */@OverridepublicStringgetValueByKey(String key){try{String value = redisTemplate.opsForValue().get(key).toString();return value;}catch(Exception e){return"";}}/**
     * 删除缓存
     * @param key
     */@Overridepublicvoiddelete(String key){
        redisTemplate.delete(key);}/**
     * 清空所有的缓存
     */@Overridepublicvoidflushdb(){
        redisTemplate.getConnectionFactory().getConnection().flushDb();}}

controller测试

@RestControllerpublicclassRedisController{//引入缓存操作@AutowiredRedisService redisService;@GetMapping("/redistest")publicStringhello(){return"hello,spring integration with redis";}@GetMapping("/redis/{key}/{val}")publicStringsavekeyValue(@PathVariable("key")String key,@PathVariable("val")Object val){
        redisService.saveKeyValue(key,val);return key+"="+redisService.getValueByKey(key);}@GetMapping("/redis/{key}")publicStringgetValueByKey(@PathVariable("key")String key){return redisService.getValueByKey(key);}@GetMapping("/redis/delete/{key}")publicStringdelete(@PathVariable("key")String key){
       redisService.delete(key);return redisService.getValueByKey(key);}}

保存数据
读取缓存
删除缓存

分布式session共享

配置session的存储类型

#指定session的存储方式spring:session:store-type: redis

配置session

@Configuration//@EnableRedisHttpSession//配置失效时间@EnableRedisHttpSession(maxInactiveIntervalInSeconds =60)//1分钟失效publicclassSessionConfig{}

session控制类

/**
 * session控制类
 */@RestControllerpublicclassSessionController{//设置session@GetMapping("/setSession/{username}")publicStringsetSession(HttpSession httpSession,@PathVariable("username")String username){
        httpSession.setAttribute("username",username);return"OK";}//获取session@GetMapping("/getSession")publicObjectgetSession(HttpSession httpSession){Object username = httpSession.getAttribute("username");return username;}}

IDEA中,我们可以改下端口重启两个服务,分布访问。

测试

在这里插入图片描述

在这里插入图片描述
超过1分钟之后,可以看到session失效。
在这里插入图片描述

标签: redis spring boot java

本文转载自: https://blog.csdn.net/qq_37400096/article/details/126631270
版权归原作者 java爱好者牛奶糖 所有, 如有侵权,请联系我们删除。

“Springboot整合redis”的评论:

还没有评论