java 生成有序不重复id生成器_分布式场景下的ID生成解决方案

2ffcfb400b36b468be07b6a3fe68c8be.gif

在服务设计中,经常遇到的一个问题就是如何生成一个全局唯一的ID,例如订单号,流水号等。对于ID的要求主要有以下几点:

  1. 全局唯一,不会存在冲突;

  2. 快速生成,能够满足高并发场景下的需求;

  3. 能够满足分布式场景下的业务需求;

  4. ID生成服务能够方便的扩容缩容。

  5. 最好基本有序;

  6. 能够附加一些业务信息,例如时间,系统标识等;

  7. 能够应对测试环境的一些特殊需求,如跳日,日期回拨等。

我们简单分析下常见的实现方式:

UUID

最熟悉的应该是UUID,UUID 是 通用唯一识别码(Universally Unique Identifier)的缩写。按照UUID规范,UUID的实现方式一共有四种:

基于时间戳的UUID。这个UUID是基于时间戳,随机数和当前机器mac地址计算得到的,可以保证全球范围内的唯一性。但是,使用mac地址为带来安全问题。

DCE(Distributed Computing Environment)安全的UUI

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值