其他分享
首页 > 其他分享> > 封装一个流水号ID生成器:id-spring-boot-starter

封装一个流水号ID生成器:id-spring-boot-starter

作者:互联网

文章转载自https://www.codesheep.cn/2019/09/04/id-springbt-starter/

概述

ID号生成器(或:全局唯一ID生成器)是服务端系统的基础设施,而且ID号这个东西基本搞后端开发的程序员天天都要接触。而关于ID生成的算法现在业界首屈一指的当属Snowflake雪花算法。

UidGenerator正是百度开源的一款基于Snowflake雪花算法实现的高性能唯一ID生成器。在本号前文中已经详细使用过UidGenerator,但使用过程还是比较繁杂,还需要自己去引UidGenerator组件的源码,感觉有点不方便。为此本文基于UidGenerator,再来封装一套更利于Spring Boot项目使用的ID号生成组件,命名为id-spring-boot-starter,一看名字就知道是开箱即用的。


用法

DROP TABLE IF EXISTS WORKER_NODE;
CREATE TABLE WORKER_NODE
(
ID BIGINT NOT NULL AUTO_INCREMENT COMMENT 'auto increment id',
HOST_NAME VARCHAR(64) NOT NULL COMMENT 'host name',
PORT VARCHAR(64) NOT NULL COMMENT 'port',
TYPE INT NOT NULL COMMENT 'node type: ACTUAL or CONTAINER',
LAUNCH_DATE DATE NOT NULL COMMENT 'launch date',
MODIFIED TIMESTAMP NOT NULL COMMENT 'modified time',
CREATED TIMESTAMP NOT NULL COMMENT 'created time',
PRIMARY KEY(ID)
)
 COMMENT='DB WorkerID Assigner for UID Generator',ENGINE = INNODB;

这一步肯定是省不掉,毕竟UidGenerator需要数据库支持

<dependency>
	<groupId>cn.codesheep</groupId>
	<artifactId>id-spring-boot-starter</artifactId>
	<version>1.0.0</version>
</dependency>
url: jdbc:mysql://xxx.xxx.xxx.xxx:3306/demo?useUnicode=true&characterEncoding=utf8&autoReconnect=true&useOldAliasMetadataBehavior=true&connectionCollation=utf8mb4_unicode_ci&rewriteBatchedStatements=true&allowMultiQueries=true
username: xxxxxx
password: xxxxxx

还是因为UidGenerator需要数据库支持

Spring Boot应用主类上加上mybatis注解即可:

@MapperScan({"com.baidu.fsg.uid.worker.dao"})
@RestController
public class TestController {

  @Autowired
  private UidGenService uidGenService;

  @GetMapping("/uid")
  public String genUid() {
    return String.valueOf("本次生成的唯一ID号为:"+uidGenService.getUid());
  }
}

怎么样,用法超级简单吧:

  1. 首先用 Autowired的方式引入UidGenService类;
  2. 直接调用UidGenService类的getUid()方法即可获得一个Long型的 ID

demo源码在此,需要请自提:


id-spring-boot-starter源码下载

需要组件id-spring-boot-starter源码进行自定制的,可以去github上自行下载源代码,地址在此:


几个注意点:

标签:COMMENT,生成器,spring,boot,id,UidGenerator,ID,starter
来源: https://blog.51cto.com/u_7692005/2991668