订单流水号生成器设计

订单流水号需求

  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做故障转移
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值