基于MySQL8.0美团leaf测试分布式ID生成系统


1.官网

美团官方介绍地址:地址
美团github地址 :地址

2. 大佬剖析源码地址

号段模式:地址
snowflake模式: 地址

3. 我为什么还要写一个呢?

  1. 官网给你github地址里面有很多坑,不建议看
  2. 大佬的github地址和官网的一样存在一个问题?MySQL8.0不支持
    因为MySQL是基于5.7搭建的,所以如果你本地MySQL版本是8.0以后的都会有问题

3.1 MySQL8.0支持

  1. pom文件改MySQL版本号为8.0.14
  <mysql-connector-java.version>8.0.14</mysql-connector-java.version>
  1. leaf.properties做下面修改
leaf.name=com.sankuai.leaf.opensource.test
# 开启号段模式
leaf.segment.enable=true
leaf.jdbc.url=jdbc:mysql://192.168.1.200:3307/leaf?characterEncoding=utf8&serverTimezone=Asia/Shanghai
leaf.jdbc.username=root
leaf.jdbc.driver-class-name=com.mysql.cj.jdbc.Driver
leaf.jdbc.password=123456
# 开启snowflake模式
leaf.snowflake.enable=true
leaf.snowflake.zk.address=localhost
leaf.snowflake.port=2181


  1. Constants类添加driver支持
public class Constants {
    public static final String LEAF_SEGMENT_ENABLE = "leaf.segment.enable";
    public static final String LEAF_JDBC_URL = "leaf.jdbc.url";
    public static final String LEAF_JDBC_USERNAME = "leaf.jdbc.username";
    public static final String LEAF_JDBC_PASSWORD = "leaf.jdbc.password";
    public static final String driver = "leaf.jdbc.driver-class-name";
    public static final String LEAF_SNOWFLAKE_ENABLE = "leaf.snowflake.enable";
    public static final String LEAF_SNOWFLAKE_PORT = "leaf.snowflake.port";
    public static final String LEAF_SNOWFLAKE_ZK_ADDRESS = "leaf.snowflake.zk.address";
}

  1. com.sankuai.inf.leaf.server.SegmentService类下面添加driver支持
  // 2. 创建Druid dataSource
  dataSource = new DruidDataSource();
  dataSource.setUrl(properties.getProperty(Constants.LEAF_JDBC_URL));
  dataSource.setUsername(properties.getProperty(Constants.LEAF_JDBC_USERNAME));
  dataSource.setDriverClassName(properties.getProperty(Constants.driver));
  dataSource.setPassword(properties.getProperty(Constants.LEAF_JDBC_PASSWORD));
  dataSource.init();

3.2其它的参考大佬的博客,里面讲的很详细

方案是为解决特定问题或达成特定目标而制定的一系列计划或步骤。它的作用是提供一种系统性的方法,以有效地应对挑战、优化流程或实现目标。以下是方案的主要作用: 问题解决: 方案的核心目标是解决问题。通过系统性的规划和执行,方案能够分析问题的根本原因,提供可行的解决方案,并引导实施过程,确保问题得到合理解决。 目标达成: 方案通常与明确的目标相关联,它提供了一种达成这些目标的计划。无论是企业战略、项目管理还是个人发展,方案的制定都有助于明确目标并提供达成目标的路径。 资源优化: 方案在设计时考虑了可用资源,以最大化其效用。通过明智的资源分配,方案可以在有限的资源条件下实现最大的效益,提高效率并减少浪费。 风险管理: 方案通常会对潜在的风险进行评估,并制定相应的风险管理策略。这有助于减轻潜在问题的影响,提高方案的可行性和可持续性。 决策支持: 方案提供了决策者所需的信息和数据,以便做出明智的决策。这种数据驱动的方法有助于减少不确定性,提高决策的准确性。 团队协作: 复杂的问题通常需要多个人的协同努力。方案提供了一个共同的框架,帮助团队成员理解各自的职责和任务,促进协作并确保整个团队朝着共同的目标努力。 监控与评估: 方案通常包括监控和评估的机制,以确保实施的有效性。通过定期的评估,可以及时调整方案,以适应变化的环境或新的挑战。 总体而言,方案的作用在于提供一种有序、有计划的方法,以解决问题、实现目标,并在实施过程中最大化资源利用和风险管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值