博客
关于我
不能错过的分布式ID生成器(Leaf ),好用的一批
阅读量:173 次
发布时间:2019-02-28

本文共 917 字,大约阅读时间需要 3 分钟。

美团Leaf分布式ID生成器技术说明

Leaf的号段模式

Leaf的号段模式是一种优化数据库自增ID的方式,旨在减少对数据库的频率操作。基本思路是批量从数据库获取号段范围,例如(1,1000]表示1000个ID。业务服务在本地生成1~1000的自增ID并加载到内存中。

号段模式的工作原理

  • 数据库表结构:Leaf使用leaf_alloc表来管理号段信息,字段包括:

    • biz_tag:唯一标识业务,支持分库分表。
    • max_id:当前号段的最大值。
    • step:号段长度。
    • update_time:数据库维护时间。
  • 号段获取:当号段耗尽时,Leaf通过更新max_id获取新的号段。例如,更新max_id= max_id + step,新号段范围为(max_id, max_id + step]

  • 缓存机制:Leaf采用双buffer缓存策略,预先加载两个号段,确保在数据库延迟或故障时仍能正常发号。

  • 优化效果:通过减少对数据库的频率操作,降低了系统响应时间,提升了性能。

  • Leaf的雪花算法模式

    Leaf的雪花算法模式结合了传统雪花算法和Zookeeper的有序服务,生成全局唯一的分布式ID。ID结构为:

    • 1位正数位(表示正数ID)
    • 41位时间戳(精确到微秒)
    • 5位机器ID
    • 5位机房ID
    • 12位自增值

    雪花算法的实现

  • Zookeeper依赖:雪花模式依赖Zookeeper生成workId。启动时,Leaf检查Zookeeper是否有对应的顺序节点:

    • 如果存在,直接使用workId启动服务。
    • 如果不存在,创建持久顺序节点并获取workId。
  • 缓存机制:Leaf在本地缓存workId,确保在Zookeeper故障时仍能正常发号。

  • 配置与启动:在leaf.properties中配置Zookeeper地址和端口,启用雪花模式即可。

  • Leaf的监控功能

    Leaf提供了实时监控界面,可查看:

    • 号段双buffer使用情况
    • 当前ID下发状态
    • 数据库维护信息

    总结

    Leaf作为美团的分布式ID生成服务,兼具号段模式和雪花算法的优势。根据业务需求灵活切换模式,支持高并发场景。其内部设计注重容灾性和性能优化,但需注意ID暴露信息和数据库依赖。

    转载地址:http://bnkc.baihongyu.com/

    你可能感兴趣的文章
    npm install 卡着不动的解决方法
    查看>>
    npm install 报错 EEXIST File exists 的解决方法
    查看>>
    npm install 报错 ERR_SOCKET_TIMEOUT 的解决方法
    查看>>
    npm install 报错 fatal: unable to connect to github.com 的解决方法
    查看>>
    npm install 报错 no such file or directory 的解决方法
    查看>>
    npm install 权限问题
    查看>>
    npm install报错,证书验证失败unable to get local issuer certificate
    查看>>
    npm install无法生成node_modules的解决方法
    查看>>
    npm install的--save和--save-dev使用说明
    查看>>
    npm node pm2相关问题
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm run build报Cannot find module错误的解决方法
    查看>>
    npm run build部署到云服务器中的Nginx(图文配置)
    查看>>
    npm run dev 报错PS ‘vite‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
    查看>>
    npm scripts 使用指南
    查看>>
    npm should be run outside of the node repl, in your normal shell
    查看>>
    npm start运行了什么
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm 下载依赖慢的解决方案(亲测有效)
    查看>>
    npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
    查看>>