redis自增(redis自增计数)

本篇文章给大家谈谈redis自增,以及redis自增计数对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

java怎么使用redis的incr的自增序列生成8位长度的id

使用spring-data-redis实配空现incr自增

/**

*

* @param key

* @param liveTime

* @return

*/

public Long incr(String key, long liveTime) {

RedisAtomicLong entityIdCounter = new RedisAtomicLong(key, redisTemplate.getConnectionFactory());

Long increment = entityIdCounter.getAndIncrement();

if ((null == increment || increment.longValue() == 0) liveTime 旦野 0) {//初始设置过期时间培迟瞎

entityIdCounter.expire(liveTime, TimeUnit.SECONDS);

}

redis实现连续自增key

Redis Incr 命令将 key 中储存的数字值增一。

如果 key 不存在,那么 key 的值会先被初始化为 0 ,然后再执行 INCR 操作。

如果值局姿包含错误的类型,或字符串类型的值不能表示为数字,那么返回一个错误。

本操作的值限制在扒腊嫌 64 位(bit)有符号数字表示之内。

java使用lua语春手法实现自增并设置有效时间:

[img]

Redis-全局唯一ID

tips:Ctrl + F快速定位所需内容阅读吧。

1、全局唯一ID特点

2、全局唯一ID生成策略

1、snowflake算法全局唯一ID策略

此处我们参考 snowflake算法的ID策略 ,其具体策略如下:

① 1位,固定位;

② 41位,用来记录时间戳(毫秒),接笑银明近69年;

③ 10位,用来记录工作机器id;

④ 12位,序列号,用来记录同毫秒内产生的不同id;

2、Redis自增全局唯一ID策略

自定义我们自己的 Redis自增的ID策略 ,具体如下:

① 1位,固定位;

② 31位,用来记录时间戳(碰告秒),接近69年;

③ 32位,序列号,用来记录同一秒内产生的不同id;

1、获取开始时间戳

LocalDateTime#of(int year, int month, int dayOfMonth, int hour, int minute, int second) 方法,传入自己需要的起始年月日时分秒;

如:2022年1月1日 00点00分00秒,为 1640995200L 。

2、编写ID生成工具类

@Component注解 ,将工具类注册到Spring容器当中,方便使用;

BEGIN_TIMESTAMP 自搏搏定义起始的时间戳;

COUNT_BITS 位移量,后续拼接全局唯一ID时使用;

timestamp 获取当前设置起始时间戳的偏移量;

拼接key ,例如:incr:order:20220325;

位运算拼接全局ID, timestamp COUNT_BITS | count; ;

3、测试生成全局唯一ID

注入RedisIdWorker对象,用于测试;

编写测试方法:

① 使用 线程池 模拟并发调用,此处简单处理;

② 使用 CountDownLatch 控制线程执行;

完整的测试方法如下:

以上即为Redis全局唯一ID的基础内容,感谢阅读。

redis 怎么使自增长主键调过一段继续生成

数据库自增什么的麻烦死了,尤其是往后还需要考虑到分布式处理,然后偷了个懒,直接redis来搞起...

下面上代码

先定义个主键生成策略接口,往后方便扩展

[java] view plain copy

/**

* 定义主键生成策略接口,以便修改扩扰运皮展

* @author LeiYong

*

*/

public interface KeyGenerate {

/**

* 生缓差成String类型主键

* @param em

* @return

*/

public String generateStringKey(KeyGenerateEnum em);

/**

* 生成long类型主键

* @param em

* @return

*/

public Long generateLongKey(KeyGenerateEnum em);

}

接下来提供一个替补队员,基础的主键生成方案,采用随机数(Long)或UUID(String)方式生成

[java] view plain copy

/**

* 基础主键生成策略,采用随机数或UUID+随机数

* @author LeiYong

*

*/

public class BaseKeyGenerate implements KeyGenerate{

@Override

public String generateStringKey(KeyGenerateEnum em) {

return StringUtil.getUUID()+StringUtil.getNonceStr(6);

}

@Override

public Long generateLongKey(KeyGenerateEnum em) {

return System.currentTimeMillis()*1000000+NumberUtil.random(6);

}

}

主角Redis的缓存主键类登场

[java] view plain copy

/**

* 采悄袜用Redis的方式产生自增长主键

* @author LeiYong

*

*/

public class RedisKeyGenerate implements KeyGenerate{

/**

* Logger for this class

*/

private final Logger logger = LoggerFactory.getLogger(RedisKeyGenerate.class);

private final String SEQUENCE_KEY = "SEQ";

@Autowired

@Qualifier("redisClientSupport")

private RedisClientSupport redisClientSupport;

@Override

public String generateStringKey(KeyGenerateEnum em) {

Long key = generateLongKey(em);

if (key!=null) {

return key.toString();

}

//为了防止redis挂了程序能够继续运行

return new BaseKeyGenerate().generateStringKey(em);

}

@Override

public Long generateLongKey(KeyGenerateEnum em) {

synchronized (em) {

try {

redisClientSupport.selectDB(SystemConfig.REDIS_INDEX_DB);

Long key = redisClientSupport.incrementHash(SEQUENCE_KEY, em.name(), 1l);

if (key != null) {

return key;

}

} catch (CacheAccessException e) {

logger.warn("generateStringKey(KeyGenerateEnum) - exception ignored", e); //$NON-NLS-1$

}

}

//为了防止redis挂了程序能够继续运行

return new BaseKeyGenerate().generateLongKey(em);

}

}

关于redis自增和redis自增计数的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

标签列表