三、Redis在SpringBoot中使用案例

本文介绍了如何在SpringBoot中配置并使用Redis,包括连接池的配置,以及Dao、Service、Controller层的实现。示例代码展示了User对象的存储和获取。文章还提及了SpringSession的使用,通过依赖和配置实现分布式session共享。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

[](()增加依赖


org.springframework.session

spring-session-data-redis

配置上面已经配置好了

[](()增加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;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值