1
0
mirror of synced 2026-02-14 08:57:56 +08:00

auto commit

This commit is contained in:
yitter
2021-04-09 22:00:22 +08:00
parent 88e6851e12
commit 768beffe4d

View File

@@ -1,5 +1,6 @@
# 雪花算法里最好用的主键ID新算法
## 💎 技术支持
开源地址1https://github.com/yitter/idgenerator
@@ -8,9 +9,19 @@
QQ群646049993
## 💎 基本介绍
<font color="#11aaff" size="5">❄</font> 一个全新的雪花算法雪花漂移生成的ID更短、速度更快。
## 为什么用雪花ID
❄ 因为大厂都在用,推特、百度、美团、滴滴等等。
❄ 雪花ID是走向分布式架构的垫脚石如果只会Guid和数据库自增怎敢说会分布式系统架构。
❄ 雪花ID适合小项目、大项目、超级大项目。
## 💎 本算法介绍
<font color="#11aaff" size="5">❄</font> 这是一个优化的雪花算法雪花漂移生成的ID更短、速度更快。
<font color="#11aaff" size="5">❄</font> 原生支持 C#/Java/Go/Rust/C 等语言,并提供 PHP、Python、Node.js、Ruby 等语言多线程安全调用库(FFI)。
@@ -21,26 +32,6 @@ QQ群646049993
<font color="#11aaff" size="5">❄</font> 这是计算机历史上最全面的雪花ID生成器未来会超越自己。目前还未发现更好的或许你可以😀
## 为什么用雪花ID
🌀 因为大厂都在用,推特、百度、美团、滴滴等等。
🌀 大厂们不但自己用,而且开源:[百度][81] | [美团][82] | [滴滴][83] | [雪花ID鼻祖-推特][80]。
🌀 雪花ID是走向分布式架构的垫脚石如果只会Guid和数据库自增怎敢说会分布式系统架构。
🌀 雪花ID适合小项目、大项目、超级大项目。
## 为什么不用大厂开源?
❄ 简而言之,大厂的雪花算法分为“经典算法”和“号段算法”两种,其中“号段算法”依赖网络或外部存储系统,不适合“非大厂”,另外“号段算法”存在业务表达上的缺陷。
❄ 至于大厂的“经典算法”其实就是推特雪花算法的特定语言翻译未曾见过大厂在“ID长度和生成性能”方面做过极致的优化而这正式本算法——雪花漂移算法的核心所在。
❄ 大厂开源都是优先为己所用,都不支持多语言,而这正式本算法——雪花漂移算法送给大家的福利,无论你是想学语言入门还是想学(或想用)雪花ID这里都能让你有所收获。
## 需求来源
<font color="green" size="5">💧</font> 作为架构设计的你,想要解决数据库主键唯一的问题,特别是在分布式系统多数据库的时候。
@@ -240,6 +231,15 @@ extern __declspec(dllexport) GoInt32 Validate(GoInt32 workerId);
| 🌲 D | [查看示例][72] | [查看示例][73] |
## 为什么不用大厂的?
❄ 首先,大厂们不但自己用,而且开源:[百度][81] | [美团][82] | [滴滴][83] | [雪花ID鼻祖-推特][80]。
❄ 然而,大厂的雪花算法分为“经典算法”和“号段算法”两种,其中“号段算法”依赖网络或外部存储系统,不适合“非大厂”。
❄ 至于其“经典算法”在“ID长度和生成性能”方面未做过优化而这正式本算法——雪花漂移算法的核心所在。
[1]: https://github.com/yitter/idgenerator/tree/master/%23.NET
[2]: https://github.com/yitter/idgenerator/tree/master/Java
[3]: https://github.com/yitter/idgenerator/tree/master/Go