一、基本概况

为什么使用缓存

缓存是在内存中存储的数据备份,当数据没有发生本质变化时

就可以直接从内存中查询数据,而不用去数据库查询(在磁盘中)

CPU读取内存的速度要比读取磁盘快,可以提高效率

Redis缓存

Remote Dictionnary Server(远程数据服务),是一款内存高速缓存数据库。

五种常用数据类型: String(字符串)、List(列表)、Set(集合)、Hash(散列)、ZSet(有序集合)

可持久化:一边运行,一边向硬盘备份一份,防止断电等偶然情况,导致内存中数据丢失

二、搭建Redis环境

1.下载Redis

2.设置Redis开机自启

在解压好的文件夹下输入cmd命令




springboot配置Redis缓存多节点 springboot整合redis缓存_redis缓存原理与实现


window下安装Redis服务

redis-server --service-install redis.windows.conf


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot内存缓存_02


检查安装是否成功
搜索服务


springboot配置Redis缓存多节点 springboot整合redis缓存_redis缓存原理与实现_03


点击设置为开机自启

三、新建SpringBoot项目

新建好项目的童鞋可以自动跳过


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot 整合redis_04


springboot配置Redis缓存多节点 springboot整合redis缓存_redis缓存原理与实现_05


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot 整合redis_06


添加web依赖


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot 整合redis_07


选择数据库依赖


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot内存缓存_08


选择项目位置,点击finish


springboot配置Redis缓存多节点 springboot整合redis缓存_redis缓存原理与实现_09


四、使用StringRedisTemplate操作Redis

1.pom.xml文件引入坐标

org.springframework.boot          spring-boot-starter-data-redis

2.在appliaction.properties配置redis数据库连接信息

#redis配置#Redis服务器地址spring.redis.host=127.0.0.1#Redis服务器连接端口spring.redis.port=6379#Redis数据库索引(默认为0)spring.redis.database=0

3.在SpringbootdemoApplicationTests中测试操作Redis

@SpringBootTestclass SpringbootdemoApplicationTests {    @Autowired    StringRedisTemplate stringRedisTemplate; //操作key-value都是字符串,最常用    @Test    public void test01(){        //字符串操作        stringRedisTemplate.opsForValue().append("msg","coder");        //列表操作        stringRedisTemplate.opsForList().leftPush("mylist","1");        stringRedisTemplate.opsForList().leftPush("mylist","2");    }}

对于Redis的五大常用数据类型都提供了方法

String(字符串)、List(列表)、Set(集合)、Hash(散列)、ZSet(有序集合)

stringRedisTemplate.opsForValue();[String(字符串)]

stringRedisTemplate.opsForList();[List(列表)]

stringRedisTemplate.opsForSet();[Set(集合)]

stringRedisTemplate.opsForHash();[Hash(散列)]

stringRedisTemplate.opsForZSet();[ZSet(有序集合)]

使用RedisDesktopManager可视化工具查看结果


springboot配置Redis缓存多节点 springboot整合redis缓存_redis缓存原理与实现_10


StringTemplate类中方法存取的key-value值是String类型,RedisTemplate中key-value值是Object类型,RedisTemplate是StringTemplate父类

下面就用RedisTemplate实现从MySQL数据库取出数据放到Redis缓存

五、使用RedisTemplate操作Redis

1.项目目录结构


springboot配置Redis缓存多节点 springboot整合redis缓存_redis缓存原理与实现_11


2.建立与数据库相关的类

建表的sql脚本

CREATE TABLE `user` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `username` varchar(32) NOT NULL COMMENT '用户名称',  `birthday` datetime DEFAULT NULL COMMENT '生日',  `sex` char(1) DEFAULT NULL COMMENT '性别',  `address` varchar(256) DEFAULT NULL COMMENT '地址',  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=49 DEFAULT CHARSET=utf8;

application.properties配置文件

  • MySQL及Redis连接的相关配置
#MySQL的配置spring.datasource.url= jdbc:mysql://localhost:3306/selfproj?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghaispring.datasource.username=rootspring.datasource.password=123456spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver#设置访问端口号server.port = 8099#redis配置#Redis服务器地址spring.redis.host=127.0.0.1#Redis服务器连接端口spring.redis.port=6379#Redis数据库索引(默认为0)spring.redis.database=0

User类

  • 采用ORM思想,属性和数据库字段对应
package com.thinkcoder.bean;import java.io.Serializable;import java.util.Date;/** * @ClassName User * @Author Think-Coder * @Data 2020/5/27 10:35 * @Version 1.0 */public class User implements Serializable {    private Integer id;    private String username;    private Date birthday;    private String sex;    private String address;//getter和setter方法    public Integer getId() {return id;}    public void setId(Integer id) {this.id = id;}    public String getUsername() {return username;}    public void setUsername(String username) {this.username = username;}    public Date getBirthday() {return birthday;}    public void setBirthday(Date birthday) {this.birthday = birthday;}    public String getSex() {return sex;}    public void setSex(String sex) {this.sex = sex;}    public String getAddress() {return address;}    public void setAddress(String address) {this.address = address;}//重写toString方法    @Override    public String toString() {        return "User{" +                "id=" + id +                ", username='" + username + ''' +                ", birthday=" + birthday +                ", sex='" + sex + ''' +                ", address='" + address + ''' +                '}';    }}

UserMapper类

  • 使用注解方法操作数据库
@Mapperpublic interface UserMapper {    @Select("SELECT * FROM user WHERE id = #{id}")    User findById(int id);}

3.MyRedisConfig

自定义序列化类,将存储在Redis的对象序列化为json格式,不会产生乱码

@Configuration@EnableAutoConfigurationpublic class MyRedisConfig {    @Bean    public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory){        RedisTemplate template = new RedisTemplate<>();        template.setConnectionFactory(redisConnectionFactory);        Jackson2JsonRedisSerializer ser = new Jackson2JsonRedisSerializer<>(User.class);        template.setDefaultSerializer(ser);        return template;    }}

4.工具类RedisUtil类

//工具类中使用Autowired注解需要加上Compoent@Componentpublic class RedisUtil {    @Autowired    RedisTemplate redisTemplate;   //key-value是对象的    //判断是否存在key    public  boolean hasKey(String key){        return redisTemplate.hasKey(key);    }    //从redis中获取值    public  Object get(String key){        return  redisTemplate.opsForValue().get(key);    }        //向redis插入值    public  boolean set(final String key,Object value){        boolean result = false;        try{             redisTemplate.opsForValue().set(key,value);            result = true;        }catch (Exception e){            e.printStackTrace();        }        return  result;    }}

5.sevice包代码

IUserService

@Servicepublic interface IUserService {//根据id查用户信息    User findById(int id);}

UserService实现类

@Servicepublic class UserServiceImpl implements IUserService {    User user;    @Autowired    UserMapper userMapper;        @Autowired    private  RedisUtil redisUtil;    @Override    public User findById(int id) {        String key = "user"+id;        if(redisUtil.hasKey(key)) {            user = (User)redisUtil.get(key);            System.out.println("查询的是缓存");        }else{            user = userMapper.findById(id);            System.out.println("查询的是数据库");            System.out.println(redisUtil.set(key,user) ? "插入成功" : "插入失败");        }        return user;    }}

6.UserController类

@RestControllerpublic class UserController {    @Autowired    IUserService userService;    @GetMapping("/user/{id}")    public User findById(@PathVariable("id") Integer id){        User user = userService.findById(id);        return user;    }}

7.测试

打开浏览器输入下方url


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot 整合redis_12


查看控制台输出


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot内存缓存_13


Redis Desktop Manager显示结果


springboot配置Redis缓存多节点 springboot整合redis缓存_springboot 整合redis_14


六、总结

整体来说,操作Redis是两个类,RedisTemplate类和StringTemplate类,为父子关系,提供的方法正好对应操作Redis数据类型的指令,所以要把数据类型及常用的指令练熟。

在实际业务中Redis的应用不止这些,继续探索吧

作者:Think—Coder