分布式系统中的唯一ID生成方法

通常在分布式系统中,有生成唯一ID的需求,唯一ID有多种实现方式。我们选择其中几种,简单阐述一下实现原理、适用场景、优缺点等信息。

目录

  • 数据库多主复制
  • UUID
  • 工单服务器
  • 雪花算法
  • 总结

数据库多主复制

数据库通常有自增属性,在单机数据库场景中自增的步长通常是1。但是,在分布式场景中,往往存在多个数据库,此时数据库自增的步长不再是1,而应该是k, k为数据库的个数。

例如有三个数据中心,A,B,C。那么步长应该为3 ,A生成的ID依次是1, 4,7, …;B生成的ID为 2,5,8,… ;C生成的步长为3,6,9…

缺点:无法灵活扩展或者收缩,当需要增加或者减少数据库数量时,调整步长会很麻烦,需要额外的同步和协作。升成的唯一ID可能是不连续的,非递增的。

适用场景:适合数据中心数量稳定,且不要求ID单调增的场景。

UUID

UUID是一个128位数据,且重复的概率极低,可忽略不计。有很多现成的接口可供调用。

UUID与时间、识别号等信息有关,也有多种格式,如GUID、标准UUID等。具体的详细信息,请参考文章https://zhuanlan.zhihu.com/p/438580928

优点:生成简单,不需要各个服务器之间协同。可以任意扩展服务器数量,而不受影响。

缺点:ID是非单调增的,不连续的。ID是非数字的,可能包含字母。

工单服务器

工单服务器由Flicker公司实现。一个Flickr 的Ticket服务器只包含一个独立的MySQL数据库服务,结合MySQL的[“REPLACE INTO”]http://dev.mysql.com/doc/refman/5.0/en/replace.html扩展,就能获取到一个ID。

详细的原理和使用方法请参考文章:Ticket Servers: Distributed Unique Primary Keys on the Cheap[https://code.flickr.net/2010/02/08/ticket-servers-distributed-unique-primary-keys-on-the-cheap/]。文中也讲述了单点故障问题的解决方法。笔者对此文也进行了简单的翻译概括,有兴趣的话可以前去查阅https://blog.csdn.net/hg_zhh/article/details/137588387

优点:ID是单调增的,是纯数字的,容易实现,更适合中小型应用。

缺点:可能存在单点故障,官方虽然给了解决方法,但是也正如官方所说的,不够优雅。

雪花算法

雪花算法由推特公司(如今的X公司)实现。这里就不详细介绍了,相信很多大佬讲解的更好更详细。主要思想是,将ID分成多个部分,每个部分单独生成,这样就很大程度避免了重复问题。雪花算法将64位的ID分成了五部分:

在这里插入图片描述

具体每个部分的长度,可以根据实际需要灵活调整。

优点:ID是纯数字的,ID是单调增的,适合中大型服务。

缺点:分布式场景中时间不同步,会导致生成ID存在偏差。如果发生始终回拨,会导致生成的ID错乱,典型的例子就是NSQ消息队列中使用雪花算法生成消息ID,但是当时间变化时,直接导致消息队列不工作,坑苦了我们!!

总结

该文只是简单的总结了一些不同的唯一ID生成方法,可能不全面,不能说哪个一定好,哪个一定差,关键是找到合适自己的,也可以在已有的方法上做针对性修改。如果文中有错误,请各位批评指正!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/544675.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

解决vue启动项目报错:npm ERR! Missing script: “serve“【详细清晰版】

目录 问题描述问题分析和解决情况一解决方法情况二(常见于vue3)解决方法情况三解决方法 问题描述 在启动vue项目时通常在控制台输入npm run serve 但是此时出现如下报错: npm ERR! Missing script: "serve" npm ERR! npm ERR! T…

80% 的人都不会的 15 个 Linux 实用技巧

熟悉 Linux 系统的同学都知道,它高效主要体现在命令行。通过命令行,可以将很多简单的命令,通过自由的组合,得到非常强大的功能。 命令行也就意味着可以自动化,自动化会使你的工作更高效,释放很多手工操作&…

纸制品ERP怎么样

在纸制品行业中, ERP系统的应用已经成为提升企业竞争力的关键因素。本文将探讨万达宝ERP系统在制造成本控制、商品生命周期管理以及自动对接主流平台方面的作用,并分析其在业务流程优化、高效调节各类关系以及多种模式生产方面的特点和益处。 制造成本控…

【数据结构(六)】队列

❣博主主页: 33的博客❣ ▶️文章专栏分类:数据结构◀️ 🚚我的代码仓库: 33的代码仓库🚚 🫵🫵🫵关注我带你学更多数据结构知识 目录 1.前言2.概念3.队列的使用4.循环队列5.双端队列6.经典习题6.1队列实现栈6.2栈实现队…

【学习笔记十】EWM自动产品包装配置

一、确定包装物料建议的程序 1.定义内向交货处理的凭证类型 2.确定包装物料建议的程序确定原理 使用可以确定包装材料建议的过程来指定业务代码。系统使用这些业务代码查找包装规格。包装期间,系统可建议包装材料。如果系统确定包装规格并建议包装材料,…

Maven创建项目

目录 1.创建项目 2.从Maven Repository: Search/Browse/Explore (mvnrepository.com)链接,下载API 3.1.0 3.在main文件内创建webapp文件夹,再webapp文件夹内创建WEB-INF文件夹,在WEB-INF文件夹内创建web.xml 4.网络编程 5.打包 6.部署 …

Python学习笔记16 - 函数

函数的创建和调用 函数调用的参数传递 函数的返回值 函数的参数定义 变量的作用域 递归函数 斐波那契数列 总结

网络编程套接字(二)之UDP服务器简单实现

目录 一、服务端UdpServer 1、udp_server.hpp 1、服务器的初始化 2、服务器的运行 2、udp_server.cc 二、客户端UdpClient udp_client.cc 三、完整代码 一、服务端UdpServer 1、udp_server.hpp 首先,我们在该文件中,将服务器封装成一个类&#…

网络抓包工具使用

一、下载安装 (1) linux: ① 使用 yum install tcpdump -y 安装 **tcpdump**工具 ② 编译安装 yum -y install gcc-c yum -y install flex yum -y install bison官网下载tcpdump和libpcap 官网地址:https://www.tcpdump.org/index.html#lat…

网红天水海英麻辣烫改名:还是商标的问题!

近日火爆网络的天水海英麻辣烫改名,改成“哈海英麻辣烫”,并打了TM,表示此商标名称商标局已经受理并下发通知书,普推知产老杨检索分析,改名的主要原因还是商标。 对于餐饮店和麻辣烫核心类别就在43类别及30类方便食品&…

表格单列相同字段值合并

用specName(el.specName row.specName)和id的区别(el.id row.id),使用id的时候id是唯一值,判断的时候不会出现重复情况,使用specName的时候,如果有重复的值,会出现合并错位的情况。 解决方案:先按照specT…

【树哈希】CF1182D Complete Mirror

CF1182D - Complete Mirror Description 给定一个 n n n 个点的无根树,求一个树根 r o o t root root,使得对于任意两个节点 v 1 , v 2 v_1,v_2 v1​,v2​,若满足 d i s t ( v 1 , r o o t ) d i s t ( v 2 , r o o t ) dist(v_1,root)dist(v_2,ro…

CUDA编程---全局内存

CUDA内存模型概述 内存的访问和管理是所有编程语言的重要部分。在现代加速器中,内存管理对高性能计算有着很大的影响。因为多数工作负载被加载和存储数据的速度所限制,所以有大量低延迟、高带宽的内存对性能是十分有利的。 然而,大容量、高性…

第十五届蓝桥杯省赛C/C++大学B组真题及赛后总结

目录 个人总结 C/C 组真题 握手问题 小球反弹 好数 R 格式 宝石组合 数字接龙 爬山 拔河 ​编辑 再总结及后续规划 个人总结 第一次参加蓝桥杯,大二,以前都在在学技术,没有系统的学过算法。所以,还是花了挺多时间去备…

【8086汇编】汇编语言基础入门

文章目录 一、汇编简介1. 汇编语言的组成2. CPU、寄存器、内存3. CPU对存储器的读写4. 拓展5. 检测6. 解析 二、寄存器1. mov、add命令2. 物理地址3. CS:IP 装段地址和偏移地址3.1 如何改变CS:IP的值 4. 数据段DS:[address]4.1 前置知识:字与字节4.2 DS:[address] 5…

串口RS485

1.原理 全双工:在同一时刻可以同时进行数据的接收和数据的发送,两者互不影响 半双工:在同一时刻只能进行数据的接收或者数据的发送,两者不能同时进行 差分信号幅值相同,相位相反,有更强的抗干扰能力。 干…

【C语言】N子棋小游戏♔

目录 前言 一、何为N子棋游戏? 二、游戏思路 三、游戏实现 3.1 模块化 3.2 游戏棋盘 3.3 下棋操作 3.3.1 玩家下棋 3.3.2 电脑下棋 3.4 判断输赢 总结 前言 三子棋小游戏相信大家都玩过吧,类似的5子琪等等,这篇文章将带着大家从0到…

【leetcode面试经典150题】28.盛最多水的容器(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主,题解使用C语言。(若有使用其他语言的同学也可了解题解思路,本质上语法内容一致&…

分享一些有趣的 Linux 命令

1、sl 会显示一辆火车穿过你的终端屏幕 2、cmatrix 在终端中显示类似于《黑客帝国》电影中的绿色数字雨效果 3、fortune 显示一个随机的名人名言或者笑话 4、cowsay 让一头牛说出你输入的话 5、toilet 在终端中将输入的文本以艺术字体的形式呈现 6、figlet 类似于 toile…

回溯算法初识

文章目录 回溯算法初识什么是回溯算法回溯算法的步骤回溯算模版例题 回溯算法初识 什么是回溯算法 ​ 回溯算法是一种通过不断尝试可能的解决方案来解决问题的算法。它通常用于解决组合优化问题,如排列组合问题、子集和问题等。该算法通过尝试所有可能的候选解&am…