Redis是一款基于内存的使用K-V结构存取数据的NoSQL非关系型数据库。
Redis的主要作用就是缓存数据,通常,会将关系型数据库(例如MySQL等)中的数据读取出来,写入到Redis中,后续,当需要获取数据时,将优先从Redis中读取,而不是从关系型数据库中读取。由于Redis是基于内存的,读写效率远高于关系型数据库,进而可以提高查询效率,并且,可以起到“保护”关系型数据库的作用。
那如何使用redis呢?
1.添加依赖
<!-- Spring Boot Data Redis依赖项,用于实现Redis编程 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
2.添加redis配置类
@Configuration
public class RedisConfiguration {
@Bean
public RedisTemplate<String, Serializable> redisTemplate(RedisConnectionFactory redisConnectionFactory) {
RedisTemplate<String, Serializable> redisTemplate = new RedisTemplate<>();
redisTemplate.setConnectionFactory(redisConnectionFactory);
redisTemplate.setKeySerializer(RedisSerializer.string());
redisTemplate.setValueSerializer(RedisSerializer.json());
return redisTemplate;
}
}
简单来讲redis就是另类的数据库
分为存和取,先存后取
当服务器端启动时,就读取MySQL数据库,并将相关数据写入到Redis中,使得“启动完成时,Redis中就已经存入了需要缓存的数据”,这种做法称之为“缓存预热”。
存数据又有数据不一致的问题,所以要执行计划任务:
第一步,既然是对redis的操作,自然要先写对redis的操作,也就是redis接口和实现类,以方便调用
1.在类上添加@Repository注解,实现接口并重写方法
2.自动装配RedisTemplate,和redis配置类相对应
RedisTemplate是SpringDataRedis中对JedisApi的高度封装,提供了redis各种操作、异常处理及序列化,支持发布订阅。
@Autowired private RedisTemplate<String, Serializable> redisTemplate;
3.在这些方法中是对redis的操作,业务逻辑层的某个实现类应该与其相对应(无非是增删改查)
第二步,在相对应数据库的业务逻辑层接口和实现类自定义rebuildCache方法,因为在业务逻辑层可以通过mapper获取全部数据,并存入redis。(当然也可以自定义,省省吧,没必要,一个方法而已)
1.删除redis的数据
2.存入对应的数据
第三步,计划任务
1.创建配置类,在配置类上使用@EnableScheduling
注解开启计划任务,并添加@Configuration注解
2.自定义组件类(组件类也就是项目启动自动创建的对象,是单例的),在类上添加@Component
3.在自定义类中,自动装配业务逻辑层。都到redis了,相信之前的mapper、service、controller已经写好了,之后看下面代码
// fixedRate:执行计划任务的间隔时间,以毫秒为单位
@Scheduled(fixedRate = 5000)
public void xxxxx() {
log.debug("开始执行计划任务……");
brandService.rebuildCache();
}
//这个配置类可以写好多计划任务的方法,方法中可以有多个任务
步骤也可以倒着看
应该从面向切面编程的角度去理解,每个对数据库操作的业务逻辑层,都有对redis的操作,而对redis的接口和实现类全部写在一个包下,这就是我的做法