司机指南 之 分布式id 的几种思路

总结:套路灰常多,而我却只钟爱下面几种,单机就不说了。

           例子1:利用数据库自增(数字)(可以设置步长),和唯一索引 ,依赖数据库 (数据库有瓶颈)  可以灵活定制规则

       注意 :name 字段唯一索引

REPLACE INTO user(`name`, `age`) VALUES ('name1', '12');
SELECT LAST_INSERT_ID();

     例子2: UUID java 自带(字符串) 不过听说有重复,百度一些也说有会重复 但是我没遇到

          

   例子3: 雪花算法(自增趋势 数字) 注意时间 同步问题 ,一般用这个问题不大 而且很高效(推荐) 但是不能自己定制规则

           

   例子4:mogodb 里面的objectId 也是个什么鬼算法(字符串)

           例子5:redis 原子 自增 可以灵活 定制 依赖redis ,(数字)比数据库性能好

                       

    @Override
    public String getCode(String key) {
        DecimalFormat df = new DecimalFormat("000");
        String cDate = DateUtil.formatDate(new Date(),"yyMMddHH");
        long code = generateCode(key);
        return cDate+df.format(code);
    }

    private long generateCode(String key){
        RedisAtomicLong counter = new RedisAtomicLong(key, redisTemplate.getConnectionFactory());
        counter.expire(1, TimeUnit.HOURS);
        return counter.incrementAndGet();
    }

  例子6:还有一些专门的id 通过http 服务直接取,不过感觉应该是也是基于上述的东东 实现的,开源的也不少,反正选一个适合自己业务的 就行。

   

 

转载于:https://www.cnblogs.com/lyc88/articles/11057470.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值