这篇文章将为大家详细讲解有关Spring Boot整合Spring Cache及redis过程的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

创新互联专注于高陵网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供高陵营销型网站建设,高陵网站制作、高陵网页设计、高陵网站官网定制、微信小程序服务,打造高陵网络公司原创品牌,更为您提供高陵网站排名全网营销落地服务。
1.安装redis
a.由于官方是没有Windows版的,所以我们需要下载微软开发的redis,网址:
https://github.com/MicrosoftArchive/redis/releases
b.解压后,在redis根目录打开cmd界面,输入:redis-server.exe redis.windows.conf,启动redis(关闭cmd窗口即停止)
2.使用
a.创建SpringBoot工程,选择maven依赖
org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-thymeleaf ..... org.springframework.boot spring-boot-starter-data-redis
b.配置 application.yml 配置文件
server: port: 8080 spring: # redis相关配置 redis: database: 0 host: localhost port: 6379 password: jedis: pool: # 连接池最大连接数(使用负值表示没有限制) max-active: 8 # 连接池最大阻塞等待时间(使用负值表示没有限制) max-wait: -1ms # 连接池中的最大空闲连接 max-idle: 5 # 连接池中的最小空闲连接 min-idle: 0 # 连接超时时间(毫秒)默认是2000ms timeout: 2000ms # thymeleaf热更新 thymeleaf: cache: false
c.创建RedisConfig配置类
@Configuration
@EnableCaching //开启缓存
public class RedisConfig {
/**
* 缓存管理器
* @param redisConnectionFactory
* @return
*/
@Bean
public RedisCacheManager cacheManager(RedisConnectionFactory redisConnectionFactory) {
// 生成一个默认配置,通过config对象即可对缓存进行自定义配置
RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig();
// 设置缓存的默认过期时间,也是使用Duration设置
config = config.entryTtl(Duration.ofMinutes(30))
// 设置 key为string序列化
.serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(new StringRedisSerializer()))
// 设置value为json序列化
.serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer()))
// 不缓存空值
.disableCachingNullValues();
// 对每个缓存空间应用不同的配置
Map configMap = new HashMap<>();
configMap.put("userCache", config.entryTtl(Duration.ofSeconds(60)));
// 使用自定义的缓存配置初始化一个cacheManager
RedisCacheManager cacheManager = RedisCacheManager.builder(redisConnectionFactory)
//默认配置
.cacheDefaults(config)
// 特殊配置(一定要先调用该方法设置初始化的缓存名,再初始化相关的配置)
.initialCacheNames(configMap.keySet())
.withInitialCacheConfigurations(configMap)
.build();
return cacheManager;
}
/**
* Redis模板类redisTemplate
* @param factory
* @return
*/
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory factory) {
RedisTemplate template = new RedisTemplate<>();
template.setConnectionFactory(factory);
// key采用String的序列化方式
template.setKeySerializer(new StringRedisSerializer());
// hash的key也采用String的序列化方式
template.setHashKeySerializer(new StringRedisSerializer());
// value序列化方式采用jackson
template.setValueSerializer(jackson2JsonRedisSerializer());
// hash的value序列化方式采用jackson
template.setHashValueSerializer(jackson2JsonRedisSerializer());
return template;
}
/**
* json序列化
* @return
*/
private RedisSerializer d.创建entity实体类
public class User implements Serializable {
private int id;
private String userName;
private String userPwd;
public User(){}
public User(int id, String userName, String userPwd) {
this.id = id;
this.userName = userName;
this.userPwd = userPwd;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public String getUserPwd() {
return userPwd;
}
public void setUserPwd(String userPwd) {
this.userPwd = userPwd;
}
}e.创建Service
@Service
public class UserService {
//查询:先查缓存是是否有,有则直接取缓存中数据,没有则运行方法中的代码并缓存
@Cacheable(value = "userCache", key = "'user:' + #userId")
public User getUser(int userId) {
System.out.println("执行此方法,说明没有缓存");
return new User(userId, "用户名(get)_" + userId, "密码_" + userId);
}
//添加:运行方法中的代码并缓存
@CachePut(value = "userCache", key = "'user:' + #user.id")
public User addUser(User user){
int userId = user.getId();
System.out.println("添加缓存");
return new User(userId, "用户名(add)_" + userId, "密码_" + userId);
}
//删除:删除缓存
@CacheEvict(value = "userCache", key = "'user:' + #userId")
public boolean deleteUser(int userId){
System.out.println("删除缓存");
return true;
}
@Cacheable(value = "common", key = "'common:user:' + #userId")
public User getCommonUser(int userId) {
System.out.println("执行此方法,说明没有缓存(测试公共配置是否生效)");
return new User(userId, "用户名(common)_" + userId, "密码_" + userId);
}
}f.创建Controller
@RestController
@RequestMapping("/user")
public class UserController {
@Resource
private UserService userService;
@RequestMapping("/getUser")
public User getUser(int userId) {
return userService.getUser(userId);
}
@RequestMapping("/addUser")
public User addUser(User user){
return userService.addUser(user);
}
@RequestMapping("/deleteUser")
public boolean deleteUser(int userId){
return userService.deleteUser(userId);
}
@RequestMapping("/getCommonUser")
public User getCommonUser(int userId) {
return userService.getCommonUser(userId);
}
}@Controller
public class HomeController {
//默认页面
@RequestMapping("/")
public String login() {
return "test";
}
}g.在 templates 目录下,写书 test.html 页面
test 测试
关于“Spring Boot整合Spring Cache及Redis过程的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。