Redis 生成分布式业务单号的实现

 更新时间:2024年04月03日 10:30:36   作者:我有一只肥螳螂  
在业务系统中很多场景下需要生成不重复的ID,本文主要介绍了Redis生成分布式业务单号的实现,具有一定的参考价值,感兴趣的可以了解一下

背景:微服务架构,有三个微服务,分别是签收、对账、开票,需要生成唯一的分布式单号

格式:标识 + 年月日 + 生成顺序(三位)

例子:

  • QS20230301001,即2023年三月一日第一张签收单
  • DZ20230212002,即2023年二月十二日第二张对账单

原理:利用 Redis 的原子性,保证三位生成顺序的唯一性

新建业务id枚举类 IdEnum

public enum IdEnum {

    SIGN("QS"),
    VERIFY("DZ"),
    INVOICE("KP"),
    RECEIPT("SK"),
    ;

    /**
     * 单号前缀
     */
    private String prefix;

    IdEnum(String prefix) {
        this.prefix = prefix;
    }

    public String getPrefix() {
        return prefix;
    }
}

新建 IdUtil

  • getCacheKey:获取 redis 的 KEY
  • getDay:获取 服务标识 + 格式化的日期
  • completionSerial:从redis获取生成顺序后,格式化为固定三位
public class IdUtil {

    static final String  PREFIX = "ID_CASH_";

    public static String getCacheKey(String serialPrefix) {
        return PREFIX.concat(serialPrefix);
    }

    public static String getDay(IdEnum idEnum) {
        DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMdd");
        StringBuffer sb = new StringBuffer();
        sb.append(idEnum.getPrefix());
        sb.append(formatter.format(LocalDateTime.now()));
        return sb.toString();
    }

    public static String completionSerial(Long serial) {
        Format formatCount = new DecimalFormat("000");
        String serialFormat = formatCount.format(serial);
        return  serialFormat;
    }
}

新建 IdService 获取分布式单号

  • dayWithPrefix :获取 服务标识 + 格式化的日期
  • redisCacheKey:Redis key
  • serial:利用 redis increment 获取原子自增数
@Service
public class IdService {

    @Resource
    private RedisTemplate redisTemplate;

    public String generateNumber(IdEnum idEnum) {
        String dayWithPrefix = IdUtil.getDay(idEnum);
        String redisCacheKey = IdUtil.getCacheKey(dayWithPrefix);
        Long serial = redisTemplate.opsForValue().increment(redisCacheKey);
        redisTemplate.expire(redisCacheKey, 2, TimeUnit.DAYS);

        String num =  dayWithPrefix + IdUtil.completionSerial(serial);
        return num;
    }
}

最后使用

String number = idService.generateNumber(IdEnum.INVOICE);

到此这篇关于Redis 生成分布式业务单号的实现的文章就介绍到这了,更多相关Redis 生成分布式业务单号内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • 硬核!15张图解Redis为什么这么快(推荐)

    硬核!15张图解Redis为什么这么快(推荐)

    作为一名服务端工程师,工作中你肯定和 Redis 打过交道。Redis为什么快,这点想必你也知道,至少为了面试也做过准备,今天通过本文给大家介绍下,感兴趣的朋友一起看看吧
    2020-10-10
  • Redis实现延迟任务的三种方法详解

    Redis实现延迟任务的三种方法详解

    延迟任务(Delayed Task)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下
    2025-04-04
  • Redis常用的数据结构及实际应用场景

    Redis常用的数据结构及实际应用场景

    本文介绍了Redis中常用的数据结构,包括字符串、列表、集合、哈希表、有序集合和Bitmap,并详细说明了它们在各种场景下的使用,需要的朋友可以参考下
    2024-05-05
  • Window server中安装Redis的超详细教程

    Window server中安装Redis的超详细教程

    这篇文章主要介绍了Window server中安装Redis的教程,本文通过图文实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-11-11
  • sentinel支持的redis高可用集群配置详解

    sentinel支持的redis高可用集群配置详解

    这篇文章主要为大家介绍了sentinel支持的redis高可用集群配置详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步早日升职加薪
    2022-04-04
  • Redisson分布式锁解锁异常问题

    Redisson分布式锁解锁异常问题

    文章主要描述了在使用Redisson进行分布式锁操作时,遇到的`IllegalMonitorStateException`异常,通过分析报错信息,作者发现了问题的根源在于线程尝试解锁但未按顺序执行,作者提出了两种解决方案:在解锁前增加判断,确保线程已获得锁
    2024-12-12
  • redis protocol通信协议及使用详解

    redis protocol通信协议及使用详解

    这篇文章主要为大家介绍了redis protocol通信协议及使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • 详解redis中的锁以及使用场景

    详解redis中的锁以及使用场景

    这篇文章主要介绍了详解redis中的锁以及使用场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 浅析PHP分布式中Redis实现Session的方法

    浅析PHP分布式中Redis实现Session的方法

    这篇文章主要介绍了PHP分布式中Redis实现Session的方法,文中详细介绍了两种方法的使用方法,并给出了测试的示例代码,有需要的朋友可以参考借鉴,下面来一起看看吧,
    2016-12-12
  • 高效异步redis客户端aredis优劣势原理解析

    高效异步redis客户端aredis优劣势原理解析

    这篇文章主要介绍了高效异步redis客户端aredis优劣势原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09

最新评论