Browse Source

auto commit

tags/v1.2
yitter 4 years ago
parent
commit
19d20f2986
1 changed files with 27 additions and 3 deletions
  1. +27
    -3
      README.md

+ 27
- 3
README.md View File

@@ -23,6 +23,26 @@ QQ群:646049993
<font color="#11aaff" size="5">❄</font> 这是计算机历史上最全面的雪花ID生成器,未来会超越自己。(目前还未发现更好的,或许你可以😀)
## 为什么要雪花ID?
🌀 因为大厂都在用,推特、百度、美团、滴滴等等。
🌀 大厂们不但自己用,而且还开源:[百度][81] | [美团][82] | [滴滴][83] | [雪花ID鼻祖-推特][80]。
🌀 雪花ID是走向分布式架构的垫脚石,如果只会Guid和数据库自增,怎么能说自己做过分布式应用系统。
🌀 要想进大厂,先学会雪花ID。
## 为什么不用大厂开源?
🌀 简而言之,大厂的雪花算法分为“经典雪花算法”和“号段雪花算法”两种,其中“号段雪花算法”依赖网络或外部存储系统,不适合“非大厂项目”,另外“号段雪花算法”存在业务表达上的缺陷。
🌀 至于大厂的“经典雪花算法”,其实就是推特雪花算法的特定语言翻译,未曾见过大厂在“ID长度和生成性能”方面,做过极致的优化,而这正式本算法——雪花漂移算法的核心所在。
🌀 另外,大厂开源都是为自己所用,没有一家支持多语言,而这正式本算法——雪花漂移算法带给大家的福利。
## 需求来源
<font color="green" size="5">💧</font> 作为架构设计的你,想要解决数据库主键唯一的问题,特别是在分布式系统多数据库的时候。
@@ -54,7 +74,7 @@ QQ群:646049993
❌ 不支持后补生成前序ID。
❌ 依赖外部存储系统。
可能依赖外部存储系统。
## 新算法特点
@@ -67,8 +87,6 @@ QQ群:646049993
<font color="green" size="5">✔</font> 支持手工插入新ID。当业务需要在历史时间生成新ID时,用本算法的预留位能生成5000个每秒。
<font color="green" size="5">✔</font> 漂移时能外发通知事件。让调用方确切知道算法漂移记录,Log并发调用量。
<font color="green" size="5">✔</font> 不依赖任何外部缓存和数据库。(k8s环境下自动注册 WorkerId 的动态库依赖 redis)
<font color="green" size="5">✔</font> 基础功能,开箱即用,无需配置文件、数据库连接等。
@@ -251,3 +269,9 @@ extern __declspec(dllexport) GoInt32 Validate(GoInt32 workerId);
[51]: https://gitee.com/yitter/idgenerator/tree/master/C
[61]: https://gitee.com/yitter/idgenerator/tree/master/ZeOthers/Vlang
[71]: https://gitee.com/yitter/idgenerator/tree/master/PHP
[80]: https://github.com/twitter-archive/snowflake
[81]: https://github.com/baidu/uid-generator
[82]: https://github.com/Meituan-Dianping/Leaf
[83]: https://github.com/didi/tinyid

Loading…
Cancel
Save