欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Spring Boot項目集成UidGenerato的方法步驟

 更新時間:2020年12月11日 09:40:51   作者:小李_同志  
這篇文章主要介紹了Spring Boot項目集成UidGenerato的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

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

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

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

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

數(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文件,使用默認配置

<?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" />
    <!-- 以下為可選配置, 如未指定將采用默認值 -->
    <!-- RingBuffer size擴容參數(shù), 可提高UID生成的吞吐量. -->
    <!-- 默認:3, 原bufferSize=8192, 擴容后bufferSize= 8192 << 3 = 65536 -->
    <!--<property name="boostPower" value="3"></property>-->
    
    <!-- 指定何時向RingBuffer中填充UID, 取值為百分比(0, 100), 默認為50 -->
    <!-- 舉例: bufferSize=1024, paddingFactor=50 -> threshold=1024 * 50 / 100 = 512. -->
    <!-- 當環(huán)上可用UID數(shù)量 < 512時, 將自動對RingBuffer進行填充補全 -->
    <!--<property name="paddingFactor" value="50"></property>-->
    
    <!-- 另外一種RingBuffer填充時機, 在Schedule線程中, 周期性檢查填充 -->
    <!-- 默認:不配置此項, 即不實用Schedule線程. 如需使用, 請指定Schedule線程時間間隔, 單位:秒 -->
    <!--<property name="scheduleInterval" value="60"></property>-->
    
    <!-- 拒絕策略: 當環(huán)已滿, 無法繼續(xù)填充時 -->
    <!-- 默認無需指定, 將丟棄Put操作, 僅日志記錄. 如有特殊需求, 請實現(xiàn)RejectedPutBufferHandler接口(支持Lambda表達式) -->
    <!--<property name="rejectedPutBufferHandler" ref="XxxxYourPutRejectPolicy"></property>-->
    
    <!-- 拒絕策略: 當環(huán)已空, 無法繼續(xù)獲取時 -->
    <!-- 默認無需指定, 將記錄日志, 并拋出UidGenerateException異常. 如有特殊需求, 請實現(xiàn)RejectedTakeBufferHandler接口(支持Lambda表達式) -->
    <!--<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());
  }
}

到此這篇關(guān)于Spring Boot項目集成UidGenerato的方法步驟的文章就介紹到這了,更多相關(guān)Spring Boot集成UidGenerato內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • Activiti7通過代碼動態(tài)生成工作流實現(xiàn)詳解

    Activiti7通過代碼動態(tài)生成工作流實現(xiàn)詳解

    這篇文章主要為大家介紹了Activiti7通過代碼動態(tài)生成工作流實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 新手了解java IO基礎(chǔ)知識

    新手了解java IO基礎(chǔ)知識

    這篇文章主要介紹了java 基礎(chǔ)知識之IO總結(jié)的相關(guān)資料,Java中的I/O分為兩種類型,一種是順序讀取,一種是隨機讀取,需要的朋友可以參考下,希望對你有幫助
    2021-07-07
  • Java中的lambda和stream實現(xiàn)排序

    Java中的lambda和stream實現(xiàn)排序

    這篇文章主要介紹了Java中的lambda和stream實現(xiàn)排序,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09
  • 如何讓Win10實現(xiàn)Java文件的開機自啟動

    如何讓Win10實現(xiàn)Java文件的開機自啟動

    這篇文章主要介紹了如何讓Win10實現(xiàn)Java文件的開機自啟動,對于一些想要一直運行的Java文件,就會造成每次系統(tǒng)更新之后的重啟導致Java文件無法繼續(xù)運行。,需要的朋友可以參考下
    2019-06-06
  • Java concurrency線程池之Callable和Future_動力節(jié)點Java學院整理

    Java concurrency線程池之Callable和Future_動力節(jié)點Java學院整理

    這篇文章主要為大家詳細介紹了Java concurrency線程池之Callable和Future,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Spring中使用copyProperties方法進行對象之間的屬性賦值詳解

    Spring中使用copyProperties方法進行對象之間的屬性賦值詳解

    這篇文章主要介紹了Spring中使用copyProperties方法進行對象之間的屬性賦值詳解,使用org.springframework.beans.BeanUtils.copyProperties方法進行對象之間屬性的賦值,避免通過get、set方法一個一個屬性的賦值,需要的朋友可以參考下
    2023-12-12
  • 本地jvm執(zhí)行flink程序帶web ui的操作

    本地jvm執(zhí)行flink程序帶web ui的操作

    這篇文章主要介紹了本地jvm執(zhí)行flink程序帶web ui的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-08-08
  • spring四種依賴注入方式的詳細介紹

    spring四種依賴注入方式的詳細介紹

    本篇文章主要介紹了spring四種依賴注入方式的詳細介紹,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • mybatis-plus分頁查詢的實現(xiàn)實例

    mybatis-plus分頁查詢的實現(xiàn)實例

    頁查詢是一項常用的數(shù)據(jù)庫查詢方法,本文主要介紹了mybatis-plus分頁查詢的實現(xiàn)實例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-06-06
  • Java并發(fā)編程之Condition源碼分析(推薦)

    Java并發(fā)編程之Condition源碼分析(推薦)

    這篇文章主要介紹了Java并發(fā)編程之Condition源碼分析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-03-03

最新評論