前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SpringBoot--操作Redis

SpringBoot--操作Redis

作者头像
aruba
发布2022-06-28 09:24:48
3120
发布2022-06-28 09:24:48
举报
文章被收录于专栏:android技术android技术

分布式--Redis的安装与数据类型的使用分布式--Redis持久化策略、主从复制、集群中我们搭建了Redis的环境,并使用了主从复制、哨兵、集群等功能,Redis环境有了,接下来就需要Java后端对Redis进行操作

一、SpringData启动器

对Redis的操作也可以使用Jedis库,但Spring公司集成了对各种NoSQL数据库操作,封装成了对应的启动器,这个项目叫SpringData,是Spring操作这些数据库的顶级项目

既然是启动器,那就很简单了,在pom文件中导入启动器,并做一定的配置即可

1. 导入依赖

SpringBoot项目中导入SpringDataRedis依赖:

代码语言:javascript
复制
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

其他配置可以看以前的文章:SpringBoot--配置MyBatis、Logback、PagerHelper、Druid

2. 配置SpringBoot

核心配置文件中,添加redis的配置:

代码语言:javascript
复制
  redis:
    host: 192.168.42.4
    cluster:
      nodes: 192.168.42.4:7001,192.168.42.4:7002,192.168.42.4:7003,192.168.42.4:7004,192.168.42.4:7005,192.168.42.4:7006
#    port: 7001
3. 注入Redis操作工具

实体类:

代码语言:javascript
复制
@Data
@AllArgsConstructor
@NoArgsConstructor
public class Dept implements Serializable {
    /**
     * 部门编号
     */
    private Integer deptno;
    /**
     * 部门名称
     */
    private String dname;
    /**
     * 地址
     */
    private String loc;
}

Redis配置类:

代码语言:javascript
复制
@Configuration
public class RedisConfigure {

    @Bean
    public RedisTemplate<String, List<Dept>> provideDeptRedisTemplate(RedisConnectionFactory factory) {
        RedisTemplate<String, List<Dept>> redisTemplate = new RedisTemplate<>();
        redisTemplate.setConnectionFactory(factory);
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<>(List.class));
        return redisTemplate;
    }

}

二、功能实现

1. mapper层
代码语言:javascript
复制
public interface DeptMapper {

    @Select("select * from dept")
    List<Dept> findAllDept();

}
2. service层

接口:

代码语言:javascript
复制
public interface DeptService {

    List<Dept> findAllDept();

}

实现:

代码语言:javascript
复制
@Service
public class DeptServiceImpl implements DeptService {

    @Autowired
    private RedisTemplate<String, List<Dept>> redisTemplate;
    @Autowired
    private DeptMapper deptMapper;

    @Override
    public List<Dept> findAllDept() {
        // 先从redis缓存中取
        List<Dept> deptList = redisTemplate.opsForValue().get("dept");
        if (deptList != null) {
            System.out.println("从缓存中取");
            return deptList;
        }

        System.out.println("从数据库中取");
        List<Dept> allDept = deptMapper.findAllDept();
        redisTemplate.opsForValue().set("dept", allDept);
        return allDept;
    }

}
3. controller层
代码语言:javascript
复制
@RestController
public class DeptController {

    @Autowired
    private DeptService deptService;

    @RequestMapping("/getDept")
    public List<Dept> getDept() {
        return deptService.findAllDept();
    }

}
4. 启动SpringBoot
代码语言:javascript
复制
@SpringBootApplication
@MapperScan("com/aruba/mapper")
public class MyApplication {

    public static void main(String[] args) {
        SpringApplication.run(MyApplication.class, args);
    }

}

访问效果:

Demo地址:

https://gitee.com/aruba/redis-study.git

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-06-28,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、SpringData启动器
    • 1. 导入依赖
      • 2. 配置SpringBoot
        • 3. 注入Redis操作工具
        • 二、功能实现
          • 1. mapper层
            • 2. service层
              • 3. controller层
                • 4. 启动SpringBoot
                • Demo地址:
                相关产品与服务
                云数据库 Redis
                腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档