写点什么

三、Redis 在 SpringBoot 中使用案例,java 程序员面试笔试真题与解析

用户头像
极客good
关注
发布于: 刚刚

</dependency>


<dependency>


<groupId>org.springframework.boot</groupId>


<artifactId>spring-boot-starter-data-redis</artifactId>


</dependency>


<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


【一线大厂Java面试题解析+核心总结学习笔记+最新架构讲解视频+实战项目源码讲义】
浏览器打开:qq.cn.hn/FTf 免费领取
复制代码


{


@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 中。下面来看


[](


)增加依赖




用户头像

极客good

关注

还未添加个人签名 2021.03.18 加入

还未添加个人简介

评论

发布
暂无评论
三、Redis在SpringBoot中使用案例,java程序员面试笔试真题与解析