首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis在SpringBoot中使用案例

Redis在SpringBoot中使用案例

作者头像
程序员爱酸奶
发布2020-03-04 18:23:47
7890
发布2020-03-04 18:23:47
举报
文章被收录于专栏:程序员爱酸奶程序员爱酸奶

祝大家中秋快乐,阖家幸福!

前言

最初的目的就想要在项目中把Redis用起来,然后最近公司的项目全部需要转成springboot,所以现在的项目都是Springboot的,自己刚好也研究下Springboot的。所以才有了下文的案例。

项目结构以及相关配置, 先创建一个springboot 项目,目录结构大体如下。

pom.xml 依赖

<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--Redis使用starter-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>

<!--注解日志/get/set-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>

<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-pool2</artifactId>
        </dependency>

说明一下,第一个依赖starter-web 是创建web应用的依赖。lombok 是我自己添加的一个依赖用来注解日志,属性的get/set方法比较方便,其他的三个依赖就是项目中使用redis的依赖啦,一般项目中想要使用redis引入这三个依赖就可以了。

在application.properties中配置redis。

#配置redis
# Redis数据库索引(默认为0)
spring.redis.database=0
# Redis服务器地址
spring.redis.host=192.168.252.53
# Redis服务器连接端口
spring.redis.port=6379
# Redis服务器连接密码(默认为空)
spring.redis.password=
# 连接池最大连接数(使用负值表示没有限制) 默认 8
spring.redis.lettuce.pool.max-active=8
# 连接池最大阻塞等待时间(使用负值表示没有限制) 默认 -1
spring.redis.lettuce.pool.max-wait=-1
# 连接池中的最大空闲连接 默认 8
spring.redis.lettuce.pool.max-idle=8
# 连接池中的最小空闲连接 默认 0
spring.redis.lettuce.pool.min-idle=0

创建Dao层

创建dao 包,创建一个User 类,这里使用了lombok提供的@Getter 和@Setter 非常方便,代码看着也很简洁。

import lombok.Getter;
import lombok.Setter;
import java.io.Serializable;

@Getter
@Setter
public class User implements Serializable {
private static final long serialVersionUID = 1L;
private Long id;
private String userName;
private String password;
private String email;
private String nickname;
private String regTime;
public User(String email, String nickname, String password, String userName, String regTime) {
super();
this.email = email;
this.nickname = nickname;
this.password = password;
this.userName = userName;
this.regTime = regTime;
    }
}

创建Service层

创建一个service 包,创建一个RedisService类,代码如下:

import com.zlf.learning.Redis.dao.User;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.stereotype.Service;
@Service
@Slf4j
public class RedisService {
@Autowired
private RedisTemplate redisTemplate;
public boolean setUser(User user){
        ValueOperations ops=redisTemplate.opsForValue();
        ops.set(user.getNickname(),user);
        log.info("{}",user.toString());
return true;
    }
public User getUser(String name){
        ValueOperations ops=redisTemplate.opsForValue();
return (User) ops.get(name);
    }
}

这里面的代码也非常的清晰,使用到的RedisTemplate ,类似于JdbcTemplate .ValueOperations ops=redisTemplate.opsForValue();就是连接了redis数据库。之后就可以从redis 中获取和添加值啦。

Controller层

创建一个controller 包,创建一个RedisController类代码如下:

@RestController
public class RedisController {
@Autowired
private RedisService redisService;
@RequestMapping("/getUser")
public User  getUser(){
String name="quellan";
return redisService.getUser(name);
    }
@RequestMapping("/setUser")
public String setUser(){
        User user=new User("aa@qq.com","quellan","123456","朱",new Date().getTime()+"");
        redisService.setUser(user);
return "添加成功";
    }
}

测 试

到此为止基础的就已经完全搭建好了,可以测试运行下。启动spring boot项目。

在redis查一下,发现redis中的key 值并不是我们设置的quellan ,而是一串。这就很难受啦!

查了一下,原来是使用的RedisTemplate ,spring-data-redis的RedisTemplate<K,V>模板类在操作redis时默认使用JdkSerializationRedisSerializer来进行序列化。这个具体的放在下一章讲吧,感觉一会讲不完,先跳过哈哈。

上面的测试说明项目中已经可以正常使用redis啦。

Session共享

按理说到上面就已经差不多,接下来来点骚操作。

分布式怎么共享session。简单来说就是一个项目部署了多个,怎么确保一个用户访问不同的项目(用户实际是无感知的,通过Nginx转发,实现负载均衡)时确保session一致。盗一张图来展示一下吧。

这张图就是多个Tomcat,那怎么实现session共享呢,就是把session存到redis中,每次去就从redis中取,这样就保证了session共享啦。

那这样是不是每次存session都需要手动存到redis中呢,常理来说当然是的,但是既然是SpringBoot 当然需要不一样啦,只需要增加一个依赖,人家就能帮你自动的加载到redis中。下面来看:

添加依赖

<dependency>
<groupId>org.springframework.session</groupId>
<artifactId>spring-session-data-redis</artifactId>
        </dependency>

配置上面已经配置好了

增加SpringSession 类

在controller 包中加一个SpringSession 类,命名可能不太规范,见谅哈!

@RestController
public class SpringSession {
@Value("${server.port}")
    Integer port;

@RequestMapping("/setSession")
public String setSession(HttpSession session){
        session.setAttribute("key","quellanAn");
return String.valueOf(port);
    }
@RequestMapping("/getSession")
public String getSession(HttpSession  session){
return session.getAttribute("key")+":"+port;
    }
}

代码很简单,就是session存一个值,get获取。这里可以看到没有任何操作redis数据库的对吧。

测试场景1

先运行项目,查看一下。

这些都没有什么,我们去redis中看一下,redis中是有session值的。

测试场景2

好了,接下来继续,因为上面还看不出来共享session。我们将项目打包成jar包运行,这样我们就可以多个端口运行啦,模拟分布式。

run.bat 中代码:

title learingPorject8090
chcp
java -jar learningproject-1.0.0.jar --server.port=8090

run2.bat 改一下端口号就好了。 然后运行jar包,在界面访问

这样就实现session共享啦。

番 外

再多说一句,设置session的过期时间 在启动类中加上注解 设置过期时间1分钟

@EnableRedisHttpSession(maxInactiveIntervalInSeconds=60)     

看到这的小伙伴,对文章有什么建议赶紧提出来吧!这一期想写 redis 的。从 redis 安装到redis 简单使用,redis主从复制,redis 持久化,哨兵模式,集群模式。由浅及深图文讲解帮助大家全面深刻的了解reidis 知识。如果大家感兴趣可以持续关注。觉得好看记得分享哟❤

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-09-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员爱酸奶 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 创建Dao层
  • 创建Service层
  • 测 试
  • Session共享
    • 增加SpringSession 类
      • 测试场景1
        • 番 外
        相关产品与服务
        云数据库 Redis
        腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档