记录实现 Redis 利用管道实现批量,锁等基础操作 扩展工具类 RedisExtUtil

简介

RedisExtUtil 是一个基于 Spring 和 RedisTemplate 的扩展工具类,旨在提供更便捷的 Redis 操作方法,包括基础的 Key-Value 操作、分布式锁以及批量操作。本篇博客将介绍该工具类的核心功能及其批量操作的使用方法。

仅仅提供参考


前置准备

在使用 RedisExtUtil 工具类之前,需要确保以下准备工作:

  • Spring 配置
<!-- 这里排除了lettuce 根据情况需不需要排除 -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</artifactId>
    <exclusions>
        <exclusion>
            <groupId>io.lettuce</groupId>
            <artifactId>lettuce-core</artifactId>
        </exclusion>
    </exclusions>
</dependency>
  • Spring 配置
@Bean
public <T> RedisTemplate<String, T> objectRedisTemplate(RedisConnectionFactory redisConnectionFactory) {
    RedisTemplate<String, T> template = new RedisTemplate<>();
    template.setConnectionFactory(redisConnectionFactory);
    template.setKeySerializer(new StringRedisSerializer());
    template.setValueSerializer(new FastJson2JsonRedisSerializer<>(Object.class));
    template.setHashKeySerializer(new StringRedisSerializer());
    template.setHashValueSerializer(new FastJson2JsonRedisSerializer<>(Object.class));
    template.afterPropertiesSet();
    return template;
}




public class FastJson2JsonRedisSerializer<T> implements RedisSerializer<T> {
    ...省略
}
  • Hutool 工具类依赖

这些依赖非关键代码,可以根据需求自行替换

import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.collection.CollectionUtil;
import cn.hutool.core.collection.ListUtil;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.map.MapUtil;
import cn.hutool.core.util.ArrayUtil;
import cn.hutool.core.util.BooleanUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.crypto.digest.DigestUtil;
import cn.hutool.extra.spring.SpringUtil;
<dependency>
    <groupId>cn.hutool</groupId>
    <artifactId>hutool-all</artifactId>
    <version>5.8.19</version>
</dependency>
  • 线程池配置
@Bean
public ThreadPoolTaskExecutor taskExecutor() {
    ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
    // 核心线程数 根据设备情况而定 这里只做演示
    executor.setCorePoolSize(10);
    // 最大线程数 根据设备情况而定 这里只做演示
    executor.setMaxPoolSize(100);
    // 队列大小 根据设备情况而定 这里只做演示
    executor.setQueueCapacity(9999);
    // 当最大池已满时,此策略保证不会丢失任务请求,但是可能会影响应用程序整体性能。 根据设备情况而定 这里只做演示
    executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
    executor.setThreadNamePrefix("异步线程-");
    executor.initialize();
    return executor;
}
  • Redis 服务

确保 Redis 服务已启动,并配置正确的连接参数。


基础方法

获取 RedisTemplate

public static <T> RedisTemplate<String, T> getDefaultRedisTemplate() {
    return SpringUtil.getBean("objectRedisTemplate", RedisTemplate.class);
}

1.Key 的生成规则

public static String calcKey(String prefix, String key) {
    return StrUtil.isBlank(prefix) ? key : prefix + key;
}

2.写入数据

public static <T> void put(String prefix, String key, T value) {
    put(getDefaultRedisTemplate(), prefix, key, value);
}

public static <T> void put(RedisTemplate<String, T> redisTe
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

NoToNull

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值