一:简介
Redis全称为Remote Dictionary Server(远程数据服务),是一款开源的基于内存的键值对存储系统,其主要被用作高性能缓存服务器使用,当然也可以作为消息中间件和Session共享等。Redis独特的键值对模型使之支持丰富的数据结构类型,即它的值可以是字符串、哈希、列表、集合、有序集合,而不像Memcached要求的键和值都是字符串。同时由于Redis是基于内存的方式,免去了磁盘I/O速度的影响,因此其读写性能极高。
二:快速上手
1、导入相关依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
<version>2.4.0</version>
</dependency>
2、编写redis配置类
@Configuration
@Slf4j
public class RedisConfiguration {
@Bean
public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){
log.info("开始创建redis模板对象...");
RedisTemplate redisTemplate = new RedisTemplate();
//设置key的序列化器
redisTemplate.setKeySerializer(new StringRedisSerializer());
redisTemplate.setConnectionFactory(redisConnectionFactory);
return redisTemplate;
}
}
3、简单使用
这里用一个user表对用户对象进行测试,查询列表时判断有没有在缓存中,如果有则直接从缓存中拿取,如果没有则从数据库中拿并缓存到redis中
@Slf4j
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private IUserService userService;
@Autowired
private RedisTemplate redisTemplate;
@ApiOperation("查询用户列表")
@GetMapping("/list")
public List<User> list(){
//查询redis中是否存在缓存数据
Set<String> keys = redisTemplate.keys("user_:*");
List list = new ArrayList();
if (keys != null && keys.size() > 0) {
for (String key : keys) {
Object user = redisTemplate.opsForValue().get(key);
list.add(user);
}
return list;
}
List<User> userList = userService.list();
Map map = new HashMap();
for (User user : userList) {
map.put("user_:user"+user.getId(),user);
redisTemplate.opsForValue().multiSet(map);
}
return userList;
}
}