Maison >développement back-end >Golang >tnfy.link - Qu'en est-il de l'identité ?
Bonjour à tous !
Il s'agit du deuxième volet de ma série tnfy.link – une plongée en profondeur dans un autre raccourcisseur d'URL ! Cet article se concentre sur les subtilités de la génération de liens courts. Bien qu'apparemment simple, la sélection de la méthode optimale présente des défis uniques.
Essentiellement, générer un lien court implique de créer un identifiant concis et unique pour chaque URL longue. Cet identifiant doit répondre à plusieurs critères :
Après une enquête approfondie, j'ai identifié quatre méthodes principales pour la création de liens courts. Examinons-les en détail.
La méthode la plus simple utilise la génération d'octets aléatoires et le codage ultérieur. Cependant, il est crucial de faire la différence entre la génération de nombres aléatoires pseudo-aléatoires et la génération de nombres aléatoires cryptographiquement sécurisée.
Go math/rand
propose un générateur de nombres pseudo-aléatoires (PRNG). L’utilisation de la même graine (valeur initiale) produit systématiquement la même séquence de nombres. Bien qu'adapté à de nombreuses applications, il ne convient pas à la génération de liens sécurisés ou imprévisibles.
Pour une sécurité renforcée, le forfait crypto/rand
est préférable. Il exploite le bruit du système pour générer des valeurs véritablement aléatoires et imprévisibles – pensez au bruit électromagnétique. Cela garantit une entropie élevée, mais les machines virtuelles s'appuyant sur leur hôte pour des données aléatoires peuvent connaître une génération plus lente sous une charge importante.
Les octets aléatoires bruts ne sont pas compatibles avec les URL ; un encodage est nécessaire. Les techniques d'encodage courantes incluent :
Pour des liens courts conviviaux, Base58 offre un équilibre optimal entre compacité et résistance aux erreurs.
Points clés :
Le hachage génère une valeur de longueur fixe à partir de l'entrée (par exemple, l'URL longue). Tout en garantissant la cohérence (une entrée identique donne toujours le même résultat), il manque de caractère aléatoire. Par conséquent, raccourcir la même URL à plusieurs reprises produit des identifiants identiques, ne répondant pas à l’exigence d’imprévisibilité.
L'ajout d'un sel aléatoire avant le hachage introduit de la variabilité, mais l'utilisation d'octets aléatoires bruts devient plus simple et plus efficace.
Les identifiants universellement uniques (UUID) sont largement utilisés pour la génération de valeur unique. Leur format par défaut est trop long pour les liens courts, mais le réencodage (par exemple en Base58) réduit la taille.
NanoID, une alternative, génère des chaînes plus courtes (21 caractères par défaut) en utilisant un alphabet personnalisable, optimisant la lisibilité et la résistance aux erreurs.
Pourquoi éviter les UUID ?
Les UUID reposent fondamentalement sur des octets aléatoires, n'offrant aucun avantage significatif par rapport à la génération directe de valeurs aléatoires.
La génération de valeurs aléatoires peut parfois conduire à des doublons, en particulier sous une charge élevée ou avec des identifiants plus courts. Bien que tnfy.link ne soit pas conçu pour les scénarios de charge élevée, les problèmes potentiels méritent d'être pris en compte.
Un compteur séquentiel garantit intrinsèquement l'unicité. Redis, à l'aide de la commande INCR, permet l'implémentation de compteurs distribués. Cependant, les identifiants séquentiels sont prévisibles. La combinaison d'une séquence avec des octets aléatoires résout ce problème, garantissant à la fois l'unicité et l'imprévisibilité.
Par exemple :
Remarque : Un composant séquentiel peut révéler le nombre total de liens générés, potentiellement indésirables dans certains contextes.
Cet article a exploré diverses méthodes de génération de liens courts :
Pour la plupart des applications, des octets aléatoires codés en base58 sont suffisants. Pour la gestion des collisions à charge élevée, la combinaison d’octets aléatoires avec un composant séquentiel est robuste. Bien qu'elle ne soit pas encore implémentée dans le backend de tnfy.link, elle est prévue comme future fonctionnalité facultative.
Merci d'avoir lu ! Vos commentaires sur la génération de liens sont les bienvenus dans les commentaires !
Article connexe
Pour en savoir plus sur mes projets, consultez mon article sur SMS Gateway pour Android.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!