redis学习(011 实战:黑马点评:优惠券秒杀:redis实现全局唯一ID)

黑马程序员Redis入门到实战教程,深度透析redis底层原理+redis分布式锁+企业解决方案+黑马点评实战项目

总时长 42:48:00 共175P

此文章包含第48p-第p49的内容


文章目录

全局唯一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
在这里插入图片描述

我们使用的是第二种
在这里插入图片描述

雪花算法也可以使用(理论上来讲它的性能应该更好)

在这里插入图片描述

雪花算法
在这里插入图片描述
缺点:对服务器时钟的依赖很严重
在这里插入图片描述


  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值