当前位置: 首页 > news >正文

JAVA后端编码的主键字段存储为什么倾向于使用雪花算法

1.背景

最近有人问,什么是雪花算法,为什么使用雪花算法不使用数据库UUID,基于此,写一个说明。

2.简介

(1)雪花算法,英文名为snowflake,翻译过来就是是雪花,所以叫雪花算法。它最早是twitter内部使用的分布式环境下的唯一分布式ID生成算法。
(2)在大自然雪花形成过程中,会形成不同的结构分支,所以说不存在两片完全一样的雪花,表示生成的id如雪花般独一无二。
注:详细介绍自行百度

2.两个优点:

(1)全局唯一
是一种分布式ID生成算法,它使用64位的时间戳、机器ID、数据中心ID和自增序列来生成全局唯一的ID,能满足高并发分布式系统环境ID不重复。
(2)生成效率
在高并发以及分布式环境下,每秒可生成百万个不重复id,生成效率极高。

3.一个缺点:

依赖于服务器时间,服务器时钟回拨时可能会生成重复id。

http://www.lryc.cn/news/318499.html

相关文章:

  • Rust 深度学习库 Burn
  • C语言-存储期2.0
  • 计算机网络面经八股-HTTP请求报文和响应报文的格式?
  • Ubuntu 18.04安装最新版Visual Studio Code(VS Code)报依赖库版本过低错误
  • Android NDK入门:在应用中加入C和C++的力量
  • 2024年华为OD机试真题-田忌赛马-Java-OD统一考试(C卷)
  • C++ 网络编程学习五
  • 案例分析篇05:数据库设计相关28个考点(9~16)(2024年软考高级系统架构设计师冲刺知识点总结系列文章)
  • pip 和conda 更换镜像源介绍
  • Git概述及安装步骤
  • 北京保险服务中心携手镜舟科技,助推新能源车险市场规范化
  • 给女朋友的浪漫微信消息推送超详细版
  • Android开发 Activity启动模式、ViewModel与LiveData,及Kotlin Coroutines
  • MQL语言实现抽象工厂模式
  • UE4开个头-简易小汽车
  • Java基础入门day04
  • 中值定理j
  • 第2篇【Docker项目实战】使用Docker部署Raneto知识库平台(转载)
  • 【Javascript】 Promise 对象(二)
  • 细说C++反向迭代器:原理与用法
  • SpringBoot(依赖管理和自动配置)
  • cad怎么转换成黑白的pdf图纸?分享3个常用的软件!
  • maven本地仓库依赖上传到远程仓库
  • ISIS多区域实验简述
  • go语言基础笔记
  • kettle 9.4和Pentoho 9.4下载及安装方法简介
  • 社交革命的引领者:探索Facebook如何改变我们的生活方式
  • 常用的推荐算法
  • 使用Python进行图片格式转化/分辨率转化
  • 植物神经功能紊乱患者每天从5片黛力新减少至2片,只因找对了治疗方法!