springboot分布式id,基于snowflake的分布式统一id生成工具

如不设置表自增长,那么此处唯一id可设置 IdType.ASSIGN_ID,单机版用mybatis默认的雪花算法IdentifierGenerator 即可,集群版推荐使用zookeeper,snowflake的分布式统一ID生成工具idworker .

java 复制代码
<!--pom添加包idworker-->  
<dependency>
            <groupId>com.imadcn.framework</groupId>
            <artifactId>idworker</artifactId>
            <version>1.6.0</version>
            <exclusions>
                <exclusion>
                    <artifactId>curator-client</artifactId>
                    <groupId>org.apache.curator</groupId>
                </exclusion>
            </exclusions>
        </dependency>
java 复制代码
package com.cn.dydatasource;

import com.baomidou.mybatisplus.autoconfigure.ConfigurationCustomizer;
import com.baomidou.mybatisplus.core.MybatisConfiguration;
import com.baomidou.mybatisplus.core.incrementer.DefaultIdentifierGenerator;
import com.baomidou.mybatisplus.core.incrementer.IdentifierGenerator;
import com.baomidou.mybatisplus.core.incrementer.ImadcnIdentifierGenerator;
import com.github.pagehelper.util.StringUtil;
import com.imadcn.framework.idworker.config.ApplicationConfiguration;
import com.imadcn.framework.idworker.config.ZookeeperConfiguration;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * 分布式id问题
 */
@Configuration()
@ConfigurationProperties(prefix = "mybatis-plus.zookeeper")
public class MybatisConfig {
    private String serverLists;

    public String getServerLists() {
        return serverLists;
    }

    public void setServerLists(String serverLists) {
        this.serverLists = serverLists;
    }


    //zookeeper 解决分布式id重复问题
    //默认是 根据ip来进行 增长的 如果ip相同  同一台机器 生成的id是不会重复的  所以同一个业务写入集部署情况 应放置在不同的服务器


    @Bean
    public IdentifierGenerator idGenerator() {
        if(!StringUtil.isEmpty(serverLists)){
            ZookeeperConfiguration zkConfig = new ZookeeperConfiguration();
            zkConfig.setServerLists(serverLists);
            zkConfig.setSessionTimeoutMilliseconds(3000);
            ApplicationConfiguration applicationConfiguration=new ApplicationConfiguration();
            applicationConfiguration.setSerialize("fastjson");
            return new ImadcnIdentifierGenerator(zkConfig,applicationConfiguration);
        }
        return  new DefaultIdentifierGenerator();
    }



}

注:application.yml中需添加zookeeper配置

相关推荐
白露与泡影2 分钟前
SpringBoot前后端token自动续期方案
spring boot·后端·状态模式
青梅主码10 分钟前
重磅!《人工智能和大型语言模型的研究前景:应用、挑战和未来方向》:代理型 AI 和大语言模型是否可以整合?
后端
hui函数25 分钟前
Flask-WTF表单验证全攻略
后端·python·flask·web·表单验证
喵手29 分钟前
Java异常处理最佳实践:如何避免捕获到不必要的异常?
java·后端·java ee
猿java41 分钟前
精通MySQL却不了解OLAP和 OLTP,正常吗?
java·后端·面试
喵手1 小时前
Java中的HashMap:你了解它的工作原理和最佳实践吗?
java·后端·java ee
冷月半明1 小时前
把离线 Python 项目塞进 Docker:从 0 到 1 的踩坑实录,一口气讲透 10 个最常见困惑
后端
用户298698530141 小时前
如何使用 Spire.Doc 在 Word 中查找和替换文本?
后端
宫水三叶的刷题日记1 小时前
真的会玩,钉钉前脚辟谣高管凌晨巡查工位,小编随后深夜发文
前端·后端·面试
天天摸鱼的java工程师1 小时前
Go 语言未来会取代 Java 吗?
java·后端