黑马程序员Redis入门到实战教程,深度透析redis底层原理+redis分布式锁+企业解决方案+黑马点评实战项目
总时长 42:48:00 共175P
此文章包含第48p-第p49的内容
文章目录
- 全局唯一ID
- 编码
全局唯一ID
//String did = dao.haveKeyId(“deputybedthing”);
这里的主键并没有自增长
店铺是使用的自增长 auto_increment
使用的是java中的Long类型 共有8个字节(64比特位)
第1位是符号位(0代表正数)
后面31位是 时间戳(以秒为单位,有21亿位,可以支持69年)
最后32位是序列号位 每秒支持2^32个id
编码
设置一个初始时间
这样设计的话,每天都会生成一个key,这个key的值正好就是当天的下单量
最好带冒号,这样到时候可以按年统计 按月统计 按日统计
这里变黄了是因为idea担心这个会产生空指针(不需要担心,redis发现没有这个key的话,会自己生成这个key)
拼接long类型,时间戳向前移动32位
用或运算 因为 向前移动了32位 后面的值全是0 0或0=0、0或1=1 所以或运算是可以直接将值放进去的
不用考虑最前面的符号位 因为这里只有63位 第一位一定是0
count & 0x00000000ffffffffL 清零序列号的高位 (0x开始表示这一串数字是以16进制表示的)
单元测试
这里我们创建一个500个线程的线程池
这里我们将生成300*100个id
这里使用线程池 等待线程都结束再进行计时
生成了30000个id
我们使用的是第二种
雪花算法也可以使用(理论上来讲它的性能应该更好)
雪花算法
缺点:对服务器时钟的依赖很严重