当前位置:网站首页>Générateur d'identification distribué basé sur redis
Générateur d'identification distribué basé sur redis
2022-07-06 12:12:00 【Un bâton.】
Basé surRedisDistribution deIDGénérateur
IDStratégie d'auto - augmentation
- Un par jourkey,Statistiques pratiques sur le volume des commandes
- IDLa construction est Horodatage + Compteur
IDLes composantes de
- Bits de symbole:1bit,Pour toujours0
- Horodatage:31bit,En secondes,De2022Année1Début du mois,Peut être utilisé68Année,Ou sur demande,Modifier pour chaque minute、Compteurs horaires ou quotidiens,Peut augmenter le temps disponible.
- Numéro de série:32bit,Compteurs quotidiens,Soutenir la production quotidienne2^32C'est différent.ID,Ou sur demande,Modifier à l'heure、Compteurs par minute ou par seconde,Mais il doit correspondre à l'horodatage,Peut être agrandiIDNombre.
Voici un horodatage en secondes et un compteur de sérialisation en joursIDGénérateur.
package cn.sticki.common.redis.utils;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
import java.time.ZoneOffset;
import java.time.format.DateTimeFormatter;
/** * @author Un poteau. * @version 1.0 * @date 2022/6/20 20:29 */
@Component
public class RedisIdGenerator {
/** * Horodatage de démarrage */
private static final long BEGIN_TIMESTAMP = 1640995200L;
/** * Nombre de chiffres du numéro de série */
private static final int COUNT_BITS = 32;
private final RedisTemplate<String, Long> redisTemplate;
public RedisIdGenerator(RedisTemplate<String, Long> redisTemplate) {
this.redisTemplate = redisTemplate;
}
@SuppressWarnings("ConstantConditions")
public long nextId(String keyPrefix) {
// 1. Générer un TIMESTAMP
LocalDateTime now = LocalDateTime.now();
long nowSecond = now.toEpochSecond(ZoneOffset.UTC);
long timestamp = nowSecond - BEGIN_TIMESTAMP;
// 2. Générer un numéro de série
// 2.1 Obtenir la date actuelle,Au jour le jour
String date = now.format(DateTimeFormatter.ofPattern("yyyy:MM:dd"));
// 2.2 Accèsredis Valeur d'auto - croissance
long increment = redisTemplate.opsForValue().increment("id:" + keyPrefix + ":" + date);
// 3. Attelage et retour
return increment << COUNT_BITS | timestamp;
}
}
Autre unique au niveau mondial IDGénérer une politique
- UUID
- RedisAuto - augmentation
- snowflakeAlgorithmes
- Base de données auto - incrémentale
边栏推荐
- 优先级反转与死锁
- level16
- 电商数据分析--用户行为分析
- RT thread API reference manual
- 几个关于指针的声明【C语言】
- Variable parameter principle of C language function: VA_ start、va_ Arg and VA_ end
- I2C bus timing explanation
- I2C总线时序详解
- Comparison of solutions of Qualcomm & MTK & Kirin mobile platform USB3.0
- Mp3mini playback module Arduino < dfrobotdfplayermini H> function explanation
猜你喜欢
荣耀Magic 3Pro 充电架构分析
几个关于指针的声明【C语言】
数据分析之缺失值填充(重点讲解多重插值法Miceforest)
电商数据分析--薪资预测(线性回归)
C language callback function [C language]
基于Redis的分布式ID生成器
[esp32 learning-1] construction of Arduino esp32 development environment
E-commerce data analysis -- User Behavior Analysis
Pytorch four commonly used optimizer tests
JS變量類型以及常用類型轉換
随机推荐
选择法排序与冒泡法排序【C语言】
RuntimeError: cuDNN error: CUDNN_STATUS_NOT_INITIALIZED
嵌入式启动流程
Redis 缓存更新策略,缓存穿透、雪崩、击穿问题
Understanding of AMBA, AHB, APB and Axi
Priority inversion and deadlock
小天才电话手表 Z3工作原理
RT-Thread的main线程“卡死”的一种可能原因及解决方案
E-commerce data analysis -- User Behavior Analysis
ESP学习问题记录
ESP8266通过arduino IED连接巴法云(TCP创客云)
PyTorch四种常用优化器测试
VIM command line notes
ToggleButton实现一个开关灯的效果
uCOS-III 的特点、任务状态、启动
Pytorch-温度预测
C语言函数之可变参数原理:va_start、va_arg及va_end
STM32 如何定位导致发生 hard fault 的代码段
Linux Yum install MySQL
Esp8266 uses Arduino to connect Alibaba cloud Internet of things