当前位置:网站首页>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
边栏推荐
猜你喜欢
Gallery's image browsing and component learning
JS variable types and common type conversions
Oppo vooc fast charging circuit and protocol
open-mmlab labelImg mmdetection
sklearn之feature_extraction.text.CountVectorizer / TfidVectorizer
A possible cause and solution of "stuck" main thread of RT thread
Kaggle competition two Sigma connect: rental listing inquiries (xgboost)
Detailed explanation of Union [C language]
IOT system framework learning
Detailed explanation of 5g working principle (explanation & illustration)
随机推荐
Types de variables JS et transformations de type communes
Unit test - unittest framework
AMBA、AHB、APB、AXI的理解
Analysis of charging architecture of glory magic 3pro
R & D thinking 01 ----- classic of embedded intelligent product development process
gcc 编译选项
Gallery's image browsing and component learning
OPPO VOOC快充电路和协议
Detailed explanation of 5g working principle (explanation & illustration)
Redis interview questions
map文件粗略分析
Comparison of solutions of Qualcomm & MTK & Kirin mobile platform USB3.0
C language callback function [C language]
C language, log print file name, function name, line number, date and time
sklearn之feature_extraction.text.CountVectorizer / TfidVectorizer
Arduino JSON data information parsing
Cannot change version of project facet Dynamic Web Module to 2.3.
物联网系统框架学习
Comparaison des solutions pour la plate - forme mobile Qualcomm & MTK & Kirin USB 3.0
Important methods of array and string