您现在的位置是:首页 > 正文

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

2024-04-01 02:18:29阅读 2

概 述

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

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

用 法

  • 首先导入SQL脚本
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需要数据库支持

  • pom中加入依赖
  <dependency>
            <artifactId>id-spring-boot-starter</artifactId>
            <groupId>org.example</groupId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
  • 配置数据库连接
server:
  port: 9999

#mybatis配置
mybatis:

  mapper-locations: classpath:mapper/*.xml
  configuration:
    map-underscore-to-camel-case: true
#Spring配置
spring:
  application:
    name: springcloud-provider-dept  #项目名字
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    driver-class-name: com.mysql.jdbc.Driver
    username: root
    password: 123456
    url: jdbc:mysql://localhost:3306/db01?useUnicode=true&characterEncoding=utf-8&allowMultiQueries=true&useSSL=false&serverTimezone=Asia/Shanghai

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

  • 修改Spring Boot主类
    Spring Boot应用主类上加上 mybatis注解即可:
@MapperScan("com.baidu.fsg.uid")
  • 代码使用方式
@RestController
public class UidController {

    @Autowired
    private UidGenService uidGenService;

    @GetMapping("/uidGenerator")
    public String UidGenerator() {
        return String.valueOf(uidGenService.getUid());
    }
}

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

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

源码下载

需要组件 id-spring-boot-starter源码进行自定制的,可以去 github上自行下载源代码,地址在此:
https://gitee.com/inverse-star/test/tree/master/springboot-demo/springboot_uid_generator/id-spring-boot-starter

几个注意点

  1. 由于 UidGenerator需要数据库支持,因此使用前一定要导数据表,并且要配置 MapperScan
  2. 需要高度定制 UidGenerator组件详情的,可以自行修改 id-spring-boot-starter内部的 cached-uid-spring.xml文件,然后重新打 jar包
  3. 由于 ID号生成一般属于系统基础服务,因此可以独立成一个微服务,供其他微服务调用

网站文章

  • 20160527 数据分析与SAS9 对考生成绩进行频率分析

    利用分析家模块对第19名考生的成绩进行频率分析检查各科分数的频率分布:1 在分析家模块打开成绩数据集test0527_12 统计--描述性统计--频数统计--除了序号全选为input是指分析变量的显示顺序:无格式、格式化取值、在数据集中的顺序、频率降序plot是指设置条形图参数:水平显示、垂直显示table是指设置输出频率:输出频数频数百分比及累积、频数累积频数、频数及百分比、

    2024-04-01 02:18:22
  • 软考项目管理师(高级)快速通过分享

    我之前写过关于 PMP 的主题分享,关注公众号「kevinsheng」后,回复「pmp」即可查看。我参加了2018年上半年的软考(计算机与软件专业技术资格考试),报考的是信息系统项目管理师(高级),前...

    2024-04-01 02:18:14
  • Java线程池ThreadPoolExecutor使用和分析(二) - execute()原理

    Java线程池ThreadPoolExecutor使用和分析(二) - execute()原理

    相关文章目录: Java线程池ThreadPoolExecutor使用和分析(一) Java线程池ThreadPoolExecutor使用和分析(二) - execute()原理 Java线程池ThreadPoolExecutor使用和分析(三) - 终止线程池原理 execute()是 java.util.concurrent.Execut...

    2024-04-01 02:17:35
  • java的快速排序怎么写?

    答案:Java的快速排序的基本思想是:首先从待排序序列中随机选择一个元素作为基准值,然后将序列中所有小于基准值的元素放到基准值的左边,将所有大于基准值的元素放到基准值的右边,然后对基准值两边的子序列重...

    2024-04-01 02:17:28
  • 打开idea报错:com.intellij.diagnostic.PluginException: Fatal error initializing ‘com.alibaba...

    打开idea报错:com.intellij.diagnostic.PluginException: Fatal error initializing ‘com.alibaba...

    PyCharm IDE安装插件后启动报错的解决方法_IF先生的博客-CSDN博客

    2024-04-01 02:17:22
  • Java使用 Executors 创建四种线程池原理

    Java使用 Executors 创建四种线程池原理

    这四种线程池本地都是通过用不同的参数去 new ThreadPoolExecutor 实现的,也就是说想要理解好这四种线程池的原理以及应用场景,还是需要去了解ThreadPoolExecutor 。 阿里开发手册上不建议使用Executors类提供的四种线程池,会出现内存溢出的错误(OOM)。

    2024-04-01 02:17:16
  • Spring框架之注解开发

    Spring框架之注解开发

    Spring是轻代码而重配置的框架,配置比较繁重,影响开发效率,所以注解开发是一种趋势。

    2024-04-01 02:16:36
  • mysql每月的第一天的日期,当月第一天的日期和前5天的日期。的MySQL

    I need a query similar to this one:SELECT *FROM myTableWHEREDATE_FORMAT(date,'%Y-%m-%d') BETWEEN <1> AND <2>Where <1> is the date of the first day of the month and <2> is the d...

    2024-04-01 02:16:29
  • struts2入门(二)启动和执行流程分析

    struts2入门(二)启动和执行流程分析

    启动过程图启动服务器,加载web.xml文件注:StrutsPreparedAndExecuteFilter过滤器是对 StrutsPrepareFilter和 StrutsExecuteFilter...

    2024-04-01 02:16:23
  • python获取星期几_如何在Python中获取日期的星期几?

    回答(15)2 years ago使用 weekday() (docs):&gt;&gt;&gt; import datetime&gt;&gt;&gt; datetime.datetime.toda...

    2024-04-01 02:15:42