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

mybatis-plus雪花算法增強(qiáng)idworker的實(shí)現(xiàn)

 更新時(shí)間:2022年07月08日 10:02:18   作者:斗者_(dá)2013  
今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,進(jìn)一步增強(qiáng)實(shí)現(xiàn)生成分布式唯一ID,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

一、官網(wǎng)

官方文檔:https://baomidou.com/

Git地址:https://github.com/baomidou/mybatis-plus

idworker官網(wǎng):https://github.com/imadcn/idworker

TIP??:
推薦學(xué)習(xí)框架的時(shí)候,多研究下官網(wǎng),獲取第一手資料。

二、默認(rèn)實(shí)現(xiàn)的弊端

在雪花算法的實(shí)現(xiàn)中,需要用戶指定datacenterIdworkerId的值。

在分布式場(chǎng)景下,如果多臺(tái)機(jī)器上的服務(wù)都指定相同的datacenterId和workerId,在高并發(fā)請(qǐng)求下,會(huì)出現(xiàn)Id重復(fù)的風(fēng)險(xiǎn)。

如下是一個(gè)雪花算法ID出現(xiàn)重復(fù)的案例:
https://github.com/imadcn/idworker/issues/14

三、mybatis-plus中datacenterId和workerId的默認(rèn)生成規(guī)則

默認(rèn)情況下,并不需要我們主動(dòng)去配置datacenterId和workerId的值。mybatis-plus框架會(huì)根據(jù)應(yīng)用所在服務(wù)器IP地址來生成datacenterId和workerId。

我們來看看DefaultIdentifierGenerator的構(gòu)造方法:

//默認(rèn)的無參構(gòu)造方法
public DefaultIdentifierGenerator() {
    this.sequence = new Sequence((InetAddress)null);
}

public DefaultIdentifierGenerator(InetAddress inetAddress) {
    this.sequence = new Sequence(inetAddress);
}

#也可以主動(dòng)指定datacenterId和workerId的值
public DefaultIdentifierGenerator(long workerId, long dataCenterId) {
    this.sequence = new Sequence(workerId, dataCenterId);
}

根據(jù)ip地址初始化Sequence:

public Sequence(InetAddress inetAddress) {
    this.inetAddress = inetAddress;
    this.datacenterId = this.getDatacenterId(31L);
    this.workerId = this.getMaxWorkerId(this.datacenterId, 31L);
}

根據(jù)ip地址生成datacenterId:

protected long getDatacenterId(long maxDatacenterId) {
        long id = 0L;

        try {
            if (null == this.inetAddress) {
                this.inetAddress = InetAddress.getLocalHost();
            }

            NetworkInterface network = NetworkInterface.getByInetAddress(this.inetAddress);
            if (null == network) {
                id = 1L;
            } else {
                byte[] mac = network.getHardwareAddress();
                if (null != mac) {
                    id = (255L & (long)mac[mac.length - 2] | 65280L & (long)mac[mac.length - 1] << 8) >> 6;
                    id %= maxDatacenterId + 1L;
                }
            }
        } catch (Exception var7) {
            logger.warn(" getDatacenterId: " + var7.getMessage());
        }

        return id;
    }

根據(jù)datacenterId生成workerId:

protected long getMaxWorkerId(long datacenterId, long maxWorkerId) {
    StringBuilder mpid = new StringBuilder();
    mpid.append(datacenterId);
    String name = ManagementFactory.getRuntimeMXBean().getName();
    if (StringUtils.isNotBlank(name)) {
        mpid.append(name.split("@")[0]);
    }

    return (long)(mpid.toString().hashCode() & '\uffff') % (maxWorkerId + 1L);
}

小結(jié):
無論是用戶自己指定datacenterIdworkerId,還是根據(jù)IP地址自動(dòng)生成datacenterIdworkerId。顯然在大規(guī)模的集群環(huán)境下都不利于集群的擴(kuò)展和維護(hù)管理,而且容易出現(xiàn)datacenterIdworkerId相同而導(dǎo)致出現(xiàn)id重復(fù)的問題。

那么有沒有方法自動(dòng)管理datacenterIdworkerId的生成呢?

四、idworker介紹

idworker 是一個(gè)基于zookeeper和snowflake算法的分布式統(tǒng)一ID生成工具,通過zookeeper自動(dòng)注冊(cè)機(jī)器(最多1024臺(tái)),無需手動(dòng)指定workerId和dataCenterId。

在分布式集群中,可能需要部署的大量的機(jī)器節(jié)點(diǎn)。在節(jié)點(diǎn)少的受,可以人工維護(hù)。在量大的場(chǎng)景下,手動(dòng)維護(hù)成本高,考慮到自動(dòng)部署、運(yùn)維等等問題,節(jié)點(diǎn)的命名,最好由系統(tǒng)自動(dòng)維護(hù)。

節(jié)點(diǎn)的命名,主要是為節(jié)點(diǎn)進(jìn)行唯一編號(hào)。主要的訴求是,不同節(jié)點(diǎn)的編號(hào),是絕對(duì)的不能重復(fù)。一旦編號(hào)重復(fù),就會(huì)導(dǎo)致有不同的節(jié)點(diǎn)碰撞,導(dǎo)致集群異常。

有以下兩個(gè)方案,可供生成集群節(jié)點(diǎn)編號(hào):
(1)使用數(shù)據(jù)庫(kù)的自增ID特性,用數(shù)據(jù)表,存儲(chǔ)機(jī)器的mac地址或者ip來維護(hù)。
(2)使用ZooKeeper持久順序節(jié)點(diǎn)的次序特性,來維護(hù)節(jié)點(diǎn)的編號(hào)。

這里,我們采用第二種,通過ZooKeeper持久順序節(jié)點(diǎn)特性,來配置維護(hù)節(jié)點(diǎn)的編號(hào)NODEID。
集群節(jié)點(diǎn)命名服務(wù)的基本流程是:
(1)啟動(dòng)節(jié)點(diǎn)服務(wù),連接ZooKeeper, 檢查命名服務(wù)根節(jié)點(diǎn)根節(jié)點(diǎn)是否存在,如果不存在就創(chuàng)建系統(tǒng)根節(jié)點(diǎn)。
(2)在根節(jié)點(diǎn)下創(chuàng)建一個(gè)臨時(shí)順序節(jié)點(diǎn),取回順序號(hào)做節(jié)點(diǎn)的NODEID。如何臨時(shí)節(jié)點(diǎn)太多,可以根據(jù)需要,刪除臨時(shí)節(jié)點(diǎn)。

由于是采用zookeeper順序節(jié)點(diǎn)的特性生成datacenterIdworkerId,可以天然的保證datacenterIdworkerId的唯一性,減少了人工維護(hù)的弊端。

五、idworker實(shí)戰(zhàn)

其中mybatis-plus內(nèi)置的ImadcnIdentifierGenerator方法,就已經(jīng)提供了對(duì)idworker框架的支持。

對(duì),你沒看錯(cuò),又又又是內(nèi)置的,可是你卻還不會(huì)用。不得不佩服mybatis-plus框架的開發(fā)者,太牛了。

查看ImadcnIdentifierGenerator的源碼,可以發(fā)現(xiàn)里面就是通過idworker實(shí)現(xiàn)的。

1、引入maven依賴

 <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.5.2</version>
    </dependency>

    <dependency>
        <groupId>com.imadcn.framework</groupId>
        <artifactId>idworker</artifactId>
        <version>1.5.0</version>
    </dependency>

2、添加zookeeper配置

mybatis-plus.zookeeper.serverLists=127.0.0.1:2181

3、指定mybatis-plus的id生成器

@Configuration
public class IdAutoConfig {
    @Value("${mybatis-plus.zookeeper.serverLists}")
    private String zkServerLists;

    @Bean
    public IdentifierGenerator idGenerator() {
        return new ImadcnIdentifierGenerator(zkServerLists);
    }
}

4、測(cè)試

執(zhí)行單元測(cè)試:

    @Test
    public void testInsert() {
        System.out.println(("----- insert method test ------"));
        User user = new User();
        user.setName("test");
        user.setAge(13);
        user.setEmail("101@qq.com");
        userMapper.insert(user);
        System.out.println(user.toString());
    }

執(zhí)行結(jié)果:

Preparing: INSERT INTO user ( id, name, age, email ) VALUES ( ?, ?, ?, ? )
Parameters: 728706665213329499(Long), test(String), 13(Integer), 101@qq.com(String)
Updates: 1
User(id=728706665213329499, name=test, age=13, email=101@qq.com)

總結(jié)

本文主要介紹如何在mybatis-plus中引入idworker框架,通過zookeeper管理snowflake算法中workerId和dataCenterId`的生成,保證其唯一性,避免出現(xiàn)id重復(fù)的情況。

到此這篇關(guān)于mybatis-plus雪花算法增強(qiáng)idworker的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)mybatis-plus idworker內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java 高并發(fā)編程之最實(shí)用的任務(wù)執(zhí)行架構(gòu)設(shè)計(jì)建議收藏

    Java 高并發(fā)編程之最實(shí)用的任務(wù)執(zhí)行架構(gòu)設(shè)計(jì)建議收藏

    高并發(fā)(High Concurrency)是互聯(lián)網(wǎng)分布式系統(tǒng)架構(gòu)設(shè)計(jì)中必須考慮的因素之一,它通常是指,通過設(shè)計(jì)保證系統(tǒng)能夠同時(shí)并行處理很多請(qǐng)求,高并發(fā)相關(guān)常用的一些指標(biāo)有響應(yīng)時(shí)間(Response Time),吞吐量(Throughput),每秒查詢率QPS(Query Per Second),并發(fā)用戶數(shù)等
    2021-10-10
  • Java常用HASH算法總結(jié)【經(jīng)典實(shí)例】

    Java常用HASH算法總結(jié)【經(jīng)典實(shí)例】

    這篇文章主要介紹了Java常用HASH算法,結(jié)合實(shí)例形式總結(jié)分析了Java常用的Hash算法,包括加法hash、旋轉(zhuǎn)hash、FNV算法、RS算法hash、PJW算法、ELF算法、BKDR算法、SDBM算法、DJB算法、DEK算法、AP算法等,需要的朋友可以參考下
    2017-09-09
  • Java源碼解析之接口Collection

    Java源碼解析之接口Collection

    Collection是List、Queue和set的超集,它直接繼承于Iterable,也就是說所有的Collection集合類都支持foreach循環(huán).除此之外呢,Collection也是面向接口編程的典范,它可以在多種實(shí)現(xiàn)類間轉(zhuǎn)換,這就是面向?qū)ο缶幊痰膮柡χ?接下來就隨著小編一起去看看吧,需要的朋友可以參考下
    2021-05-05
  • ShardingSphere解析SQL示例詳解

    ShardingSphere解析SQL示例詳解

    這篇文章主要為大家介紹了ShardingSphere解析SQL的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • java9版本特性資源自動(dòng)關(guān)閉的語(yǔ)法增強(qiáng)

    java9版本特性資源自動(dòng)關(guān)閉的語(yǔ)法增強(qiáng)

    這篇文章主要為大家介紹了java9版本特性資源自動(dòng)關(guān)閉的語(yǔ)法增強(qiáng)的詳細(xì)使用說明,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • spring cloud gateway使用 uri: lb://方式配置時(shí),服務(wù)名的特殊要求

    spring cloud gateway使用 uri: lb://方式配置時(shí),服務(wù)名的特殊要求

    這篇文章主要介紹了spring cloud gateway使用 uri: lb://方式配置時(shí),服務(wù)名的特殊要求,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • MyBatis源碼淺析(一)開篇

    MyBatis源碼淺析(一)開篇

    源碼的學(xué)習(xí)好處多多,Mybatis源碼量少、邏輯簡(jiǎn)單。下面將通過本文給大家詳解,低mybatis源碼淺析感興趣的朋友一起看看吧
    2016-11-11
  • Java 刪除文件及文件夾刪除不了的解決

    Java 刪除文件及文件夾刪除不了的解決

    這篇文章主要介紹了Java 刪除文件及文件夾刪除不了的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • Mybatis自定義Sql模板語(yǔ)法問題

    Mybatis自定義Sql模板語(yǔ)法問題

    這篇文章主要介紹了Mybatis自定義Sql模板語(yǔ)法問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 淺談SpringBoot資源初始化加載的幾種方式

    淺談SpringBoot資源初始化加載的幾種方式

    在平時(shí)的業(yè)務(wù)模塊開發(fā)過程中,難免會(huì)需要做一些全局的任務(wù)、緩存、線程等等的初始化工作,那么如何解決這個(gè)問題呢?本文就來介紹一下,感興趣的可以了解一下
    2021-07-07

最新評(píng)論