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