2021-10-11

spring data redis(一):基本内容


前言

Redis是一个基于内存的键(key)值(value) 类型的数据结构存储容器,因为数据是存在内存中的,所以读写速度非常快,因此 redis 被广泛应用于缓存方向。所以当某些不专业的面试官问你,你为什么不使用本地内存进行存储时,你可以很自豪地回答他,Redis就是基于内存的。另外,redis 也经常用来做分布式锁。redis 目前提供了5 种数据类型来支持不同的业务场景。比如基于zset可以实现排行榜,基于list可以用户列表。除此之外,redis 支持事务 、持久化、LUA脚本、LRU驱动事件、多种集群方案。最为关键的是Redis的工作线程是单线程,支持原子性操作。


一、Redis数据内存

在这里插入图片描述

二、使用案例

1.配置pom.xml和application.properties

<!-- redis -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!--commons pool2 创建连接池 -->
<dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-pool2</artifactId>
</dependency>
<!-- jackson 序列化  安全版本:https://www.huaweicloud.com/notice/2018/20190801135923810.html -->
<dependency>
<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.9.10.3</version>
</dependency>
# redis
spring.redis.host=localhost
# 连接端口号
spring.redis.port=6379
# 数据库索引 默认 0
spring.redis.database=0
# 连接池最大连接数 (默认:8)
spring.redis.lettuce.pool.max-active=8
# 连接池最小空闲连接 (默认:0)
spring.redis.lettuce.pool.min-idle=0
# 连接池最大阻塞等待时间,赋值表示没有限制 (默认:-1)
spring.redis.lettuce.pool.max-wait=-1ms
# 连接池最大空闲连接 (默认:8)
spring.redis.lettuce.pool.max-idle=8

2.创建实体类和配置类

@Entity
public class User implements Serializable {

    private static final long serialVersionUID = -390763540622907853L;
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    private String name;

    private Integer age;
    
    private String email;

    // 省略构造器 set/get		

}
@Configuration
public class RedisConfig {

    @Bean
    public RedisTemplate<String, Object> redisTemplate(
            RedisConnectionFactory redisConnectionFactory)
            throws UnknownHostException {
        RedisTemplate<String, Object> template = new RedisTemplate<>();
        template.setConnectionFactory(redisConnectionFactory);

        //使用Jackson2JsonRedisSerializer来序列化和反序列化redis的value值
        Jackson2JsonRedisSerializer serializer = new Jackson2JsonRedisSerializer(Object.class);

        ObjectMapper mapper = new ObjectMapper();
        //设置输入时忽略JSON字符串中存在而Java对象实际没有的属性
        mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false);
        mapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        // mapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        serializer.setObjectMapper(mapper);
        mapper.setDateFormat(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"));
        template.setValueSerializer(serializer);
        //使用StringRedisSerializer来序列化和反序列化redis的key值
        template.setKeySerializer(new StringRedisSerializer());
        template.setHashKeySerializer(new StringRedisSerializer());
        template.setHashValueSerializer(serializer);
        template.afterPropertiesSet();
        return template;
    }

}

配置主要解决 RedisTemplate 序列化问题, RedisTemplate 使用默认 JdkSerializationRedisSerializer的序列d对象,在存入数据会将数据先序列化成字节数组然后在存入 Redis 数据库,通过工具查询也是字节数组显示。

分析序列化方式:

  • RedisTemplate:使用的是 JdkSerializationRedisSerializer
  • StringRedisTemplate:使用的是 StringRedisSerializer,字符串类型可以直接使用不用序列化。

测试总结

我们使用散列表hash进行测试:

@Test
public void redisHashTest() {
    redisTemplate.opsForHash().put("userInfo", "name", "姓名");
    redisTemplate.opsForHash().put("userInfo", "age", 20);
    // 删除
    redisTemplate.opsForHash().delete("userInfo", "sex");
    // 获取 userInfo name value
    logger.info("result = {}", redisTemplate.opsForHash().get("userInfo", "name"));
    // 查询 哈希键中的 fields
    logger.info("result = {}", redisTemplate.opsForHash().keys("userInfo"));
    // 查询哈希键中的所有 field 的 value
    logger.info("result = {}", redisTemplate.opsForHash().values("userInfo"));
}

结果显示

result = 姓名 //name的value是姓名
result = [name, age]//key值是name,age
result = [姓名, 20]//value值是姓名,20
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值