谈谈常用的分布式 ID 设计方案

常用的分布式 ID 设计方案有以下几种:

  1. 数据库自增 ID

    • 优点:简单,天然有序。

    • 缺点:并发性不好,数据库写压力大,数据库故障后不可使用,存在数量泄露风险。

    • 优化方案

      • 数据库水平拆分,设置不同的初始值和相同的自增步长。

      • 基于数据库的号段模式,即预先在数据库中生成一段 ID 号段,应用启动时获取该号段,当本地的号段快用完时,再去数据库获取新的号段。

  2. UUID

    • 优点:简单易用,无需依赖中心化服务,生成速度快,适用于无需严格顺序的场景。

    • 缺点:UUID 比较长,占用存储空间大,不保证 ID 生成的有序性,可能会影响数据库索引效率。

  3. Snowflake 雪花算法

    • 优点:高性能、分布式环境下无冲突,易于水平扩展,适用于大规模分布式系统,生成的 ID 是全局唯一的,且可以保证高效地生成,不依赖于集中式服务。

    • 缺点:时间戳位有一定的时钟回拨问题,需要预先分配机器 ID,可能会导致机器数目限制。

    • 变种与改进

      • MongoDB ObjectId:使用 12 字节存储时间戳、机器 ID、进程 ID 和计数器,适用于非数值型 ID 场景。

      • 美团的 Leaf:支持号段模式和 Snowflake 模式,适应不同业务需求。

      • 百度的 UidGenerator:通过环形缓冲(Ring Buffer)提升吞吐量,解决高并发下性能问题。

  4. 基于 Redis 的 incr 命令

    • 优点 :利用 Redis 的单线程模型来保证分布式 ID 的唯一性,而 INCR 命令则保证了分布式 ID 的有序性。

    • 实现方法

      • 初始化数据,设置分布式 ID 的初始结构。

      • 对于单机模式下的 Redis,直接使用 INCR 命令即可保证有序性。

      • 对于集群模式下的 Redis,给每个节点设置不同的初始偏移量,并使用 INCRBY 命令指定集群中所有节点数量的步长来保证全局唯一性。

  5. Google 的 Spanner

    • 优点:通过 TrueTime API 来保证全球时间的一致性,从而生成全局唯一的 ID。

    • 缺点:实现复杂,需要依赖于 Google 的基础设施,对于一般的分布式系统来说成本较高。

在选择分布式 ID 生成策略时,需要考虑性能要求、ID 有序性、存储与传输、分布式架构等因素。

相关推荐
qq_12498707536 小时前
基于Hadoop的信贷风险评估的数据可视化分析与预测系统的设计与实现(源码+论文+部署+安装)
大数据·人工智能·hadoop·分布式·信息可视化·毕业设计·计算机毕业设计
Coder_Boy_9 小时前
基于Spring AI的分布式在线考试系统-事件处理架构实现方案
人工智能·spring boot·分布式·spring
袁煦丞 cpolar内网穿透实验室10 小时前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar
人间打气筒(Ada)10 小时前
GlusterFS实现KVM高可用及热迁移
分布式·虚拟化·kvm·高可用·glusterfs·热迁移
xu_yule10 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式
難釋懷14 小时前
分布式锁的原子性问题
分布式
ai_xiaogui15 小时前
【开源前瞻】从“咸鱼”到“超级个体”:谈谈 Panelai 分布式子服务器管理系统的设计架构与 UI 演进
服务器·分布式·架构·分布式架构·panelai·开源面板·ai工具开发
凯子坚持 c16 小时前
如何基于 CANN 原生能力,构建一个支持 QoS 感知的 LLM 推理调度器
分布式
飞升不如收破烂~16 小时前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式