1 Star 0 Fork 2

高业明/tinyid

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

介绍

Tinyid是用Java开发的一款分布式id生成系统,基于数据库号段算法实现;参照的是滴滴开源的TinyId:https://github.com/didi/tinyid/wiki/tinyid%E5%8E%9F%E7%90%86%E4%BB%8B%E7%BB%8D

软件架构

使用技术

jdk1.8+maven+mysql+h2+http

安装教程

  1. tinyid-application模块下的resoureces目录下mybatis-generator-core-1.3.2.jar是mybatis生成中文注解插件;使用附件mybatis-generator-core-install.mvn安装即可
  2. mvn clean install -Ph2编译后即可本地运行,使用的是h2内存数据;由init_db.sqlinit_data.sql自动进行初始化;
  3. mvn clean install -Pmysql则使用的是mysql数据库,可自行将配置文件application-mysql.properties数据库相关配置修改成本地mysql数据库即可
  4. 运行成功后,访问:

tinyid的原理

  • tinyid是基于数据库发号算法实现的,简单来说是数据库中保存了可用的id号段,tinyid会将可用号段加载到内存中,之后生成id会直接内存中产生。

  • 可用号段在第一次获取id时加载,如当前号段使用达到一定量时,会异步加载下一可用号段,保证内存中始终有可用号段。

  • (如可用号段~1000被加载到内存,则获取id时,会从1开始递增获取,当使用到一定百分比时,如20%(默认),即200时,会异步加载下一可用号段到内存,假设新加载的号段是1001~2000,则此时内存中可用号段为200~1000,1001~2000),当id递增到1000时,当前号段使用完毕,下一号段会替换为当前号段。依次类推。

其他说明

  • 关于tinyid,是参照滴滴开源的TinyId进行简单改造之后的。具体可以参照滴滴开源的TinyId

空文件

简介

分布式id方案之号段模式 展开 收起
Java
取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/gaoyeming/tinyid.git
git@gitee.com:gaoyeming/tinyid.git
gaoyeming
tinyid
tinyid
master

搜索帮助