更新时间:2020-07-09 来源:黑马程序员 浏览量:
当我们web系统处于初期系统的时候,用户量比较小,我们的数据库的数据生成主键的时候可以采用increment自增策略,简单的做id的唯一生成器, 这种模式我们的web服务器不需要做额外的操作就可以保证数据库中主键是唯一的,但是随着业务量和用户量增长,我们就会做web集群和数据库集群。如下图所示:
在图中,我们发现当数据库集群化,就不能在使用increment自增了(这里暂时不考虑oracle的sequence的方案,因为oracle要钱啊,手动滑稽)。因为数据库自增长是依赖表的,分表分库之后就不行了。这时候我们需要一个策略可以实现id的自增且不唯一,这里给出一个方案使用redis的方案,因为redis是单线程的。不会有线程安全问题,redis提供了incr和incrby两种安全的自增方法。我们可以在web服务器端直接调用redis的方案.在业务层就给出一个唯一自增的id。如下图所示:
如图中所示我们可以使用同一的redis服务器生成id,具体的代码实现 这里使用java实现 使用jedis作为通信的工具包,封装两个工具类。第一个类是用来封装跟redis获取连接相关工具类。
这里需要用到一个配置文件:
接下来是redis生成id工具类
我们就可以直接用IDGenerator的next方法传入一个字符串作为key生成id 比如说要为用户生成id,可以给出一个"user"字符串 。
猜你喜欢:
SpringBoot整合Redis来实现缓存技术
Java中级程序员学培训课程
【AI设计】北京143期毕业仅36天,全员拿下高薪offer!黑马AI设计连续6期100%高薪就业
2025-09-19【跨境电商运营】深圳跨境电商运营毕业22个工作日,就业率91%+,最高薪资达13500元
2025-09-19【AI运维】郑州运维1期就业班,毕业14个工作日,班级93%同学已拿到Offer, 一线均薪资 1W+
2025-09-19【AI鸿蒙开发】上海校区AI鸿蒙开发4期5期,距离毕业21天,就业率91%,平均薪资14046元
2025-09-19【AI大模型开发-Python】毕业33个工作日,就业率已达到94.55%,班均薪资20763元
2025-09-19【AI智能应用开发-Java】毕业5个工作日就业率98.18%,最高薪资 17.5k*13薪,全班平均薪资9244元
2025-09-19