redis生成自增长的ID

redis生成自增长的ID

当我们web系统处于初期系统的时候,用户量比较小,我们的数据库的数据生成主键的时候可以采用increment自增策略,简单的做id的唯一生成器,

这种模式我们的web服务器不需要做额外的操作就可以保证数据库中主键是唯一的.但是随着业务量和用户量增长,我们就会做web集群和数据库集群

如下图所示

redis生成自增长的ID_第1张图片

在图中,我们发现当数据库集群化,就不能在使用increment自增了(这里暂时不考虑oracle的sequence的方案,因为oracle要钱啊,手动滑稽).因为数据库自增长是依赖表的,分表分库之后就不行了. 这时候我们需要一个策略可以实现id的自增且不唯一,这里给出一个方案使用redis的方案,因为redis是单线程的.不会有线程安全问题,redis提供了incr 和incrby两种安全的自增方法.我们可以在web服务器端直接调用redis的方案.在业务层就给出一个唯一自增的id. 如下图所示:

redis生成自增长的ID_第2张图片

如图中所示我们可以使用同一的redis服务器生成id,具体的代码实现 这里使用java实现 使用jedis作

你可能感兴趣的:(javaweb)