当前位置:网站首页>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

image-20220621171917673

  • 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
原网站

版权声明
本文为[Un bâton.]所创,转载请带上原文链接,感谢
https://yzsam.com/2022/187/202207060913400889.html