订单流水号生成器设计

订单流水号需求

  1. 每天的流水号从1开始,流水号不重复,按照时间有序
  2. 流水号生成器支持大并发,不低于10000并发,生成效率高,不超过20ms,考虑网络环境因素
  3. 流水号生成器支持持久化和故障转移

[编辑]实现设计

  1. 使用ttserver作为存储器实现,使用ttserver的hash存储模式,这种模式支持完整的memcached的协议,可以使用increment指令对某一字段执行原子性加1,并返回加1后的值
  2. 无论是memcached还是ttserver都需要数据库中预先存储一个key然后才能加1,如果没有这个key,则每次返回-1
    1. 使用一个linux定时器在每月的15号插入下个月的所有key,key是日期比如20120701,值是0,那么调用increment指令得到的是1
    2. 另一个linux定时器在16-18号随机检查下个月的key是否已经存在,如果没有发邮件报警
  3. ttserver的数据是支持持久化的,同时支持双机复制,可以使用一个keepalived做故障转移

你可能感兴趣的:(设计)