RedisTemplate使用详解

本文详细介绍了Spring Data Redis中RedisTemplate的使用,包括Spring-data-redis的简介,SpringBoot整合Redis的步骤,配置序列化方式,以及如何通过RedisTemplate操作Redis的五种数据类型:string、hash、list、set和zset。
摘要由CSDN通过智能技术生成

目录

一、Spring Data Redis

?1、Spring-data-redis简介

2、Spring-data-redis 针对 Jedis 提供的功能

二、SpringBoot整合Redis加入Redis依赖及序列化依赖

三、增加Redis配置类,为key、value配置序列化方式

四、配置Redis工具类,将RedisTemplate的API统一管理

五、RedisTemplate针对Redis五种数据类型的操作

1、RedisTemplate操作string类型数据

2、RedisTemplate操作hash类型数据

3、RedisTemplate操作list类型数据

4、RedisTemplate操作set类型数据

5、RedisTemplate操作zset类型数据


一、Spring Data Redis

1、Spring-data-redis简介

Spring-data-redis提供了在Spring应用中通过简单的配置访问redis服务,对reids底层开发包(Jedis, JRedis, and RJC)进行了高度封装,封装了 RedisTemplate 对象来进行对Redis的各种操作、异常处理及序列化,支持发布订阅,并对Spring 3.1 cache进行了实现,它支持所有的Redis原生的 API。

2、Spring-data-redis 针对 Jedis 提供的功能

1、连接池自动管理,提供了一个高度封装的“RedisTemplate”类;
2、针对jedis客户端中大量api进行了归类封装,将同一类型操作封装为operation接口

  • ValueOperations:简单的K-V操作
  • SetOperations:set类型数据操作
  • ZSetOperations:zset类型数据操作
  • HashOperations:针对map类型的数据操作
  • ListOperations:针对list类型的数据操作

3、提供了对key的“bound”(绑定)便捷化操作API,可以通过bound封装指定的key,然后进行一系列的操作而无须“显式”的再次指定Key,即BoundKeyOperations:

  • BoundValueOperations
  • BoundSetOperations
  • BoundListOperations
  • BoundSetOperations
  • BoundHashOperations

4、将事务操作封装,有容器控制。
5、针对数据的“序列化/反序列化”,提供了多种可选择策略(RedisSerializer)

  • JdkSerializationRedisSerializer:POJO对象的存取场景,使用JDK本身序列化机制,将pojo类通过ObjectInputStream/ObjectOutputStream进行序列化操作,最终redis-server中将存储字节序列。是目前最常用的序列化策略。
  • StringRedisSerializer:Key或者value为字符串的场景,根据指定的charset对数据的字节序列编码成string,是“new String(bytes, charset)”和“string.getBytes(charset)”的直接封装。是最轻量级和高效的策略。
  • JacksonJsonRedisSerializer:jackson-json工具提供了javabean与json之间的转换能力,可以将pojo实例序列化成json格式存储在redis中,也可以将json格式的数据转换成pojo实例。

在项目中,我们经常会用到RedisTemplate来操作Redis,本文详细罗列了RedisTemplate操作Redis的方法。

二、SpringBoot整合Redis加入Redis依赖及序列化依赖

<!-- redis依赖 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- fastjson -->
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.76</version>
</dependency>

三、增加Redis配置类,为key、value配置序列化方式

package com.test.redis.redis;

import com.alibaba.fastjson.support.spring.FastJsonRedisSerializer;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;

/**
 * @ClassName RedisConfig
 * @Description Redis配置类
 * @Author chengjunyu
 * @Date 2022/2/11
 * @Version 1.0
 */
@Configuration
public class RedisConfig {

    @Bean
    @ConditionalOnMissingBean(name = "redisTemplate")
    public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory connectionFactory) {
        RedisTemplate<String, Object> redisTemplate = new RedisTemplate<String, Object>();
        // fastjson序列化
        FastJsonRedisSerializer fastJsonRedisSerializer = new FastJsonRedisSerializer(Object.class);
        // key的序列化采用StringRedisSerializer
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        redisTemplate.setHashKeySerializer(new StringRedisSerializer());
        // value的序列化采用FastJsonRedisSerializer
        redisTemplate.setValueSerializer(fastJsonRedisSerializer);
        redisTemplate.setHashValueSerializer(fastJsonRedisSerializer);
        redisTemplate.setConnectionFactory(connectionFactory);
        return redisTemplate;
    }

    @Bean
    @ConditionalOnMissingBean(StringRedisTemplate.class)
    public StringRedisTemplate stringRedisTemplate(RedisConnectionFactory connectionFactory) {
        StringRedisTemplate stringRedisTemplate = new StringRedisTemplate();
        stringRedisTemplate.setConnectionFactory(connectionFactory);
        return stringRedisTemplate;
    }

}

四、配置Redis工具类,将RedisTemplate的API统一管理

/**
 * @ClassName RedisUtil
 * @Description Redis工具类
 * @Author chengjunyu
 * @Date 2022/2/11
 * @Version 1.0
 */
public class RedisUtil {

    @Autowired
    private RedisTemplate<String, Object> redisTemplate;

}

五、RedisTemplate针对Redis五种数据类型的操作

1、RedisTemplate操作string类型数据

    /**
     * @description string设置 key和 value的值
     * @author chengjunyu
     * @date 2022/2/11
     * @param key
     * @param value
     * @return void
     */
    public void set(String key, Object value) {
        redisTemplate.opsForValue().set(key, value);
    }

    /**
     * @description string设置 key和 value的值并设置过期时间和时间单位
     * @author chengjunyu
     * @date 2022/2/12
     * @param key
     * @param value
     * @param seconds
     * @param timeUnit
     * @return void
     */
    public void setWithExpire(String key, Object value, Long seconds, TimeUnit timeUnit) {
        redisTemplate.opsForValue().set(key, value, seconds, timeUnit);
    }

    /**
     * @description string获取 key对应的 value值
     * @author chengjunyu
     * @date 2022/2/11
     * @param  * @param key
     * @return java.lang.Object
     */
    public Object get(String key) {
        return redisTemplate.opsForValue().get(key);
    }

    /**
     * @description 判断在 redis中是不是存在对应的 key值,有的话就返回 true,没有就返回 false
     * @author chengjunyu
     * @date 2022/2/11
     * @param  * @param key
     * @return boolean    
     */
    public Boolean hasKey(String key) {
        return redisTemplate.hasKey(key);
    }

    /**
     * @description 删除redis中对应的key值
     * @author chengjunyu
     * @date 2022/2/11
     * @param key
     * @
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RedisTemplate是Spring Data Redis提供的一个用于操作Redis的模板类,它封装了Redis的连接、数据序列化、异常处理等操作,使得我们可以更加方便地使用Redis。下面是RedisTemplate使用详解: 1. 配置RedisTemplate 在Spring Boot中,我们可以通过配置文件来配置RedisTemplate,如下所示: ``` spring.redis.host=127.0.0.1 spring.redis.port=6379 spring.redis.password= spring.redis.database=0 ``` 2. 注入RedisTemplate 在需要使用Redis的地方,我们可以通过注入RedisTemplate来获取Redis连接,如下所示: ``` @Autowired private RedisTemplate<String, Object> redisTemplate; ``` 3. RedisTemplate常用操作 RedisTemplate提供了多种操作Redis的方法,下面是一些常用的操作: - 字符串操作 ``` redisTemplate.opsForValue().set("key", "value"); redisTemplate.opsForValue().get("key"); ``` - 列表操作 ``` redisTemplate.opsForList().leftPush("list", "value"); redisTemplate.opsForList().rightPop("list"); ``` - 集合操作 ``` redisTemplate.opsForSet().add("set", "value"); redisTemplate.opsForSet().members("set"); ``` - 哈希操作 ``` redisTemplate.opsForHash().put("hash", "key", "value"); redisTemplate.opsForHash().get("hash", "key"); ``` - 事务操作 ``` redisTemplate.execute(new SessionCallback<Object>() { @Override public Object execute(RedisOperations operations) throws DataAccessException { operations.multi(); operations.opsForValue().set("key1", "value1"); operations.opsForValue().set("key2", "value2"); operations.exec(); return null; } }); ``` 4. Lua脚本操作 Redis支持使用Lua脚本进行操作,可以提高Redis的性能和安全性。下面是一个使用Lua脚本进行加锁的例子: ``` String lockKey = "lock"; String requestId = UUID.randomUUID().toString(); String script = "if redis.call('setnx', KEYS[1], ARGV[1]) == 1 then return redis.call('expire', KEYS[1], ARGV[2]) else return 0 end"; Boolean result = redisTemplate.execute(new RedisCallback<Boolean>() { @Override public Boolean doInRedis(RedisConnection connection) throws DataAccessException { Object nativeConnection = connection.getNativeConnection(); if (nativeConnection instanceof Jedis) { return (Boolean) ((Jedis) nativeConnection).eval(script, Collections.singletonList(lockKey), Arrays.asList(requestId, "60")); } return false; } }); ``` 这个例子中,我们使用Lua脚本实现了一个分布式锁,可以避免多个线程同时访问同一个资源的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值