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