SpringBoot--操作Redis

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

一、SpringData启动器

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

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

1. 导入依赖

SpringBoot项目中导入SpringDataRedis依赖:

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

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

2. 配置SpringBoot

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

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操作工具

实体类:

@Data
@AllArgsConstructor
@NoArgsConstructor
public class Dept implements Serializable {
    /**
     * 部门编号
     */
    private Integer deptno;
    /**
     * 部门名称
     */
    private String dname;
    /**
     * 地址
     */
    private String loc;
}

Redis配置类:

@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层
public interface DeptMapper {

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

}
2. service层

接口:

public interface DeptService {

    List<Dept> findAllDept();

}

实现:

@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层
@RestController
public class DeptController {

    @Autowired
    private DeptService deptService;

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

}
4. 启动SpringBoot
@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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值