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

本文主要是介绍redis学习(011 实战:黑马点评:优惠券秒杀:redis实现全局唯一ID),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

黑马程序员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
在这里插入图片描述

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

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

在这里插入图片描述

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


这篇关于redis学习(011 实战:黑马点评:优惠券秒杀:redis实现全局唯一ID)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1133704

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Redis 基本数据类型和使用详解

《Redis基本数据类型和使用详解》String是Redis最基本的数据类型,一个键对应一个值,它的功能十分强大,可以存储字符串、整数、浮点数等多种数据格式,本文给大家介绍Redis基本数据类型和... 目录一、Redis 入门介绍二、Redis 的五大基本数据类型2.1 String 类型2.2 Hash

Redis中Hash从使用过程到原理说明

《Redis中Hash从使用过程到原理说明》RedisHash结构用于存储字段-值对,适合对象数据,支持HSET、HGET等命令,采用ziplist或hashtable编码,通过渐进式rehash优化... 目录一、开篇:Hash就像超市的货架二、Hash的基本使用1. 常用命令示例2. Java操作示例三

Redis中Set结构使用过程与原理说明

《Redis中Set结构使用过程与原理说明》本文解析了RedisSet数据结构,涵盖其基本操作(如添加、查找)、集合运算(交并差)、底层实现(intset与hashtable自动切换机制)、典型应用场... 目录开篇:从购物车到Redis Set一、Redis Set的基本操作1.1 编程常用命令1.2 集