如何使用SpringBoot項目集成UidGenerator

本篇內(nèi)容主要講解“ 如何使用Spring Boot項目集成UidGenerator”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“ 如何使用Spring Boot項目集成UidGenerator”吧!

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名注冊、雅安服務(wù)器托管、營銷軟件、網(wǎng)站建設(shè)、清苑網(wǎng)站維護、網(wǎng)站推廣。

  • 前言

UidGenerator 基于snowflake算法實現(xiàn)  

            UidGenerator 由百度開發(fā),基于SnowFlake算法的唯一ID生成器。UidGenerator 已組件的形式工作在應(yīng)用項目中,支持自定義workeid位數(shù)和初始化策略,從而適用docker等虛擬化環(huán)境下實例自動重啟等場景。  

  • 準(zhǔn)備一個maven項目,構(gòu)建兩個模塊。分別作為使用方和提供方。(建兩個模塊主要是為了“造輪子”,其他模塊或項目可以直接引用,無需關(guān)心uid配置,如果沒有分模塊,可以忽略構(gòu)建兩個模塊)

  • 下載uid源碼,放在項目中,開源地址 https://github.com/baidu/uid-generator

如何使用Spring Boot項目集成UidGenerator

  • 數(shù)據(jù)庫建表

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;
  • Spring 配置

    CachedUidGennerator:

    UidGenerator 有兩個具體的實現(xiàn)類,分別是 DefaultUidGenerator 和 CachedUidGenerator, 官方推薦使用性能較強的 CachedUidGenerator。

        我們直接引用 UdiGenerator源碼中的 cached-uid-spring.xml文件,使用默認(rèn)配置

<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd">
    <!-- UID generator -->
    <bean id="disposableWorkerIdAssigner" class="com.baidu.fsg.uid.worker.DisposableWorkerIdAssigner" />
    <bean id="cachedUidGenerator" class="com.baidu.fsg.uid.impl.CachedUidGenerator">
        <property name="workerIdAssigner" ref="disposableWorkerIdAssigner" />
        <!-- 以下為可選配置, 如未指定將采用默認(rèn)值 -->
        <!-- RingBuffer size擴容參數(shù), 可提高UID生成的吞吐量. -->
        <!-- 默認(rèn):3, 原bufferSize=8192, 擴容后bufferSize= 8192 << 3 = 65536 -->
        <!--<property name="boostPower" value="3"></property>-->
        
        <!-- 指定何時向RingBuffer中填充UID, 取值為百分比(0, 100), 默認(rèn)為50 -->
        <!-- 舉例: bufferSize=1024, paddingFactor=50 -> threshold=1024 * 50 / 100 = 512. -->
        <!-- 當(dāng)環(huán)上可用UID數(shù)量 < 512時, 將自動對RingBuffer進行填充補全 -->
        <!--<property name="paddingFactor" value="50"></property>-->
        
        <!-- 另外一種RingBuffer填充時機, 在Schedule線程中, 周期性檢查填充 -->
        <!-- 默認(rèn):不配置此項, 即不實用Schedule線程. 如需使用, 請指定Schedule線程時間間隔, 單位:秒 -->
        <!--<property name="scheduleInterval" value="60"></property>-->
        
        <!-- 拒絕策略: 當(dāng)環(huán)已滿, 無法繼續(xù)填充時 -->
        <!-- 默認(rèn)無需指定, 將丟棄Put操作, 僅日志記錄. 如有特殊需求, 請實現(xiàn)RejectedPutBufferHandler接口(支持Lambda表達(dá)式) -->
        <!--<property name="rejectedPutBufferHandler" ref="XxxxYourPutRejectPolicy"></property>-->
        
        <!-- 拒絕策略: 當(dāng)環(huán)已空, 無法繼續(xù)獲取時 -->
        <!-- 默認(rèn)無需指定, 將記錄日志, 并拋出UidGenerateException異常. 如有特殊需求, 請實現(xiàn)RejectedTakeBufferHandler接口(支持Lambda表達(dá)式) -->
        <!--<property name="rejectedPutBufferHandler" ref="XxxxYourPutRejectPolicy"></property>-->
        
    </bean>
</beans>

引入cached-uid-spring.xml配置文件,在我們自己新建的 UidConfig中 

package com.xxx.uid.config;


import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.ImportResource;


/**
* @author lishuzhen
* @date 2020/8/11 16:10
*/
@Configuration
@ImportResource(locations = {"classpath:/uid/cached-uid-spring.xml"})
public class UidConfig {
}

在另一個模塊中maven引入,創(chuàng)建一個UidGenUtils工具類,方便使用  

package com.xxxx.utils;


import com.xxx.uid.UidGenerator;
import org.springframework.stereotype.Component;


import javax.annotation.Resource;


/**
* @author lishuzhen
* @date 2020/8/11 16:13
*/
@Component
public class UidGenUtils {
    @Resource
    private UidGenerator uidGenerator;


    public long getUid() {
        return uidGenerator.getUID();
    }


    public String getUidStr() {
        return String.valueOf(uidGenerator.getUID());
    }
}

到此,相信大家對“ 如何使用Spring Boot項目集成UidGenerator”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

網(wǎng)站標(biāo)題:如何使用SpringBoot項目集成UidGenerator
網(wǎng)站網(wǎng)址:http://muchs.cn/article44/pipcee.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開發(fā)、企業(yè)網(wǎng)站制作、App設(shè)計做網(wǎng)站、商城網(wǎng)站、用戶體驗

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)