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配置

相关推荐
专职12 分钟前
spring boot中实现手动分页
java·spring boot·后端
指尖下的技术20 分钟前
Kafka面试题----Kafka消息是采用Pull模式,还是Push模式
分布式·kafka
Ciderw21 分钟前
Go中的三种锁
开发语言·c++·后端·golang·互斥锁·
m0_748246351 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端
m0_748230441 小时前
创建一个Spring Boot项目
java·spring boot·后端
卿着飞翔1 小时前
Java面试题2025-Mysql
java·spring boot·后端
C++小厨神1 小时前
C#语言的学习路线
开发语言·后端·golang
计算机-秋大田2 小时前
基于微信小程序的校园失物招领系统设计与实现(LW+源码+讲解)
java·前端·后端·微信小程序·小程序·课程设计
綦枫Maple2 小时前
Spring Boot(6)解决ruoyi框架连续快速发送post请求时,弹出“数据正在处理,请勿重复提交”提醒的问题
java·spring boot·后端
码至终章2 小时前
kafka常用目录文件解析
java·分布式·后端·kafka·mq