司机指南 之 分布式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 服务直接取,不过感觉应该是也是基于上述的东东 实现的,开源的也不少,反正选一个适合自己业务的 就行。

   

 

posted @ 2019-06-20 11:00  川流不息&  阅读(186)  评论(0编辑  收藏  举报