lua学习笔记之-----5行代码完成ID发号器

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了lua学习笔记之-----5行代码完成ID发号器相关的知识,希望对你有一定的参考价值。

版权归作者所有,任何形式转载请联系作者。

 

--生成ID的位数比较合理长度为52个bit,然后可以时间上有序的,包含项目和实例信息

-- 在redis客户端执行: redis-cli -h 127.0.0.1 -p 6379 EVAL "$(cat ticketID.lua)" 2 01 02
-- EVAL 后面的参数解释 "$(cat ticketID.lua)"是我们执行的lua脚本文件,
-- "2"是代表传入lua脚本的参数有两个KEY,
-- "01"表示projectID,我上面用4个bit 所以可以指定取值01至15
-- "02"表示实例ID,可以指定01-15

-- 更多关于redis的EVAL的说明,请参考: http://redis.io/commands/EVAL

--更多详细的ID生成策略,建议参考大拿们的博客:http://weibo.com/p/1001603800404851831206

1 -- project id 占用 4个 bit
2 local projectId = KEYS[1]
3 -- instance id 占用 4个 bit
4 local instanceId = KEYS[2]
5 --sequence占用16个bit
6 local sequence = redis.call("INCR", "TICKET_ID") % 65536
7 --减去2016-05-08的时间戳,主要是因为位数有限,time占用28个bit
8 local time = redis.call("TIME")[1] - 1462636800
9 return time * 16777216 + projectId * 1048576 + instanceId * 65536 + sequence

 

以上是关于lua学习笔记之-----5行代码完成ID发号器的主要内容,如果未能解决你的问题,请参考以下文章

发号器的设计

FAQ系列 | 用MySQL实现发号器

野谈系列之高性能可定制化分布式发号器

野谈系列之高性能可定制化分布式发号器

分布式——分布式发号器

分布式ID生成器PHP+Swoole实现介绍