Maison base de données Redis Opérations de structure de données Redis et Golang : comment stocker et indexer efficacement les données

Opérations de structure de données Redis et Golang : comment stocker et indexer efficacement les données

Jul 30, 2023 pm 06:33 PM
redis golang 数据结构操作

Opérations de structure de données de Redis et Golang : Comment stocker et indexer efficacement les données

Introduction :
Dans les applications Internet modernes, le stockage et l'indexation des données sont des éléments très importants. Redis, en tant que base de données en mémoire hautes performances, combinée à Golang, un langage de programmation puissant, peut nous aider à stocker et indexer efficacement les données. Cet article présentera les opérations de structure de données entre Redis et Golang, et comment les utiliser pour stocker et indexer efficacement les données.

1. Structure de données Redis
Redis prend en charge une variété de structures de données, notamment String, List, Hash, Set et Sorted Set. Chaque structure de données a ses scénarios d'application et ses méthodes de fonctionnement spécifiques.

  1. String (String)
    String est la structure de données la plus basique de Redis. Vous pouvez définir la valeur d'une chaîne via la commande SET et obtenir la valeur de la chaîne via la commande GET.
import "github.com/go-redis/redis"
client := redis.NewClient(&redis.Options{
    Addr:     "localhost:6379",
    Password: "",
    DB:       0,
})

err := client.Set("key", "value", 0).Err()
if err != nil {
    panic(err)
}

value, err := client.Get("key").Result()
if err != nil {
    panic(err)
}
fmt.Println("key:", value)
Copier après la connexion
  1. List (List)
    Une liste est une collection de chaînes ordonnées. Vous pouvez utiliser la commande LPUSH pour insérer un ou plusieurs éléments sur le côté gauche de la liste et la commande RPUSH pour insérer un ou plusieurs éléments sur le côté droit de la liste. Vous pouvez utiliser la commande LLEN pour obtenir la longueur de la liste, et les commandes LPOP et RPOP pour obtenir respectivement le premier et le dernier élément de la liste.
// LPUSH
err := client.LPush("list", "element1", "element2").Err()
if err != nil {
    panic(err)
}

// RPUSH
err := client.RPush("list", "element3").Err()
if err != nil {
    panic(err)
}

// LLEN
length, err := client.LLen("list").Result()
if err != nil {
    panic(err)
}
fmt.Println("list length:", length)

// LPOP
value, err := client.LPop("list").Result()
if err != nil {
    panic(err)
}
fmt.Println("popped value:", value)

// RPOP
value, err := client.RPop("list").Result()
if err != nil {
    panic(err)
}
fmt.Println("popped value:", value)
Copier après la connexion
  1. Hash (Hash)
    Hash est une collection de paires clé-valeur. Vous pouvez définir la paire clé-valeur de hachage via la commande HSET, obtenir la valeur de hachage via la commande HGET et supprimer la paire clé-valeur de hachage via la commande HDEL.
// HSET
err := client.HSet("hash", "field", "value").Err()
if err != nil {
    panic(err)
}

// HGET
value, err := client.HGet("hash", "field").Result()
if err != nil {
    panic(err)
}
fmt.Println("value:", value)

// HDEL
err := client.HDel("hash", "field").Err()
if err != nil {
    panic(err)
}
Copier après la connexion
  1. Set (Set)
    Un ensemble est une collection non ordonnée d'éléments. Vous pouvez ajouter un ou plusieurs éléments à un ensemble via la commande SADD, obtenir tous les éléments de l'ensemble via la commande SMEMBERS et déterminer si un élément existe dans l'ensemble via la commande SISMEMBER.
// SADD
err := client.SAdd("set", "element1", "element2").Err()
if err != nil {
    panic(err)
}

// SMEMBERS
elements, err := client.SMembers("set").Result()
if err != nil {
    panic(err)
}
fmt.Println("elements:", elements)

// SISMEMBER
exists, err := client.SIsMember("set", "element1").Result()
if err != nil {
    panic(err)
}
fmt.Println("element1 exists in set:", exists)
Copier après la connexion
  1. Ensemble ordonné (ensemble trié)
    Un ensemble ordonné est un ensemble ordonné d'éléments. Vous pouvez utiliser la commande ZADD pour ajouter un ou plusieurs éléments avec des scores à l'ensemble ordonné, et utiliser la commande ZREVRANGE pour classer les éléments du plus grand au plus petit par score.
// ZADD
err := client.ZAdd("sortedset", &redis.Z{Score: 1, Member: "element1"}, &redis.Z{Score: 2, Member: "element2"}).Err()
if err != nil {
    panic(err)
}

// ZREVRANGE
elements, err := client.ZRevRange("sortedset", 0, -1).Result()
if err != nil {
    panic(err)
}
fmt.Println("elements:", elements)
Copier après la connexion

2. Application combinée de Redis et Golang
Grâce à l'exemple de code ci-dessus, nous comprenons comment utiliser différentes structures de données et commandes de Redis pour stocker et indexer des données. Alors, comment combiner Redis avec Golang ? Ce qui suit prend un exemple de code simple pour montrer comment utiliser Redis et Golang pour implémenter une connexion utilisateur efficace et enregistrer les temps de connexion.

import (
    "fmt"
    "github.com/go-redis/redis"
)

func main() {
    // 连接Redis
    client := redis.NewClient(&redis.Options{
        Addr:     "localhost:6379",
        Password: "",
        DB:       0,
    })

    // 用户登录
    username := "user1"
    password := "123456"

    // 校验用户名和密码
    if checkLogin(client, username, password) {
        fmt.Println("Login success!")
    } else {
        fmt.Println("Login failed!")
    }

    // 记录登录次数
    loginTimes := getLoginTimes(client, username)
    fmt.Println("Login times:", loginTimes)
}

// 检查用户名和密码
func checkLogin(client *redis.Client, username string, password string) bool {
    // 从Redis获取密码
    savedPwd, err := client.Get(username).Result()
    if err != nil {
        panic(err)
    }

    // 校验密码
    if savedPwd == password {
        // 登录成功,增加登录次数
        client.Incr(username + "_times").Result()
        return true
    }

    return false
}

// 获取登录次数
func getLoginTimes(client *redis.Client, username string) int64 {
    times, err := client.Get(username + "_times").Int64()
    if err != nil {
        panic(err)
    }
    return times
}
Copier après la connexion

Dans l'exemple de code ci-dessus, nous vérifions si le nom d'utilisateur et le mot de passe correspondent via la fonction checkLogin. Si la correspondance réussit, les temps de connexion de l'utilisateur sont augmentés via la commande client.Incr et les temps de connexion de l'utilisateur sont obtenus via la commande client.Incr. la fonction getLoginTimes.

Conclusion :
Grâce à la structure de données de Redis et aux capacités de programmation de Golang, nous pouvons stocker et indexer les données efficacement. En utilisant les différentes structures de données et commandes fournies par Redis, combinées aux puissantes fonctionnalités du langage de programmation de Golang, nous pouvons implémenter des fonctions de stockage et d'indexation de données plus complexes et plus efficaces, offrant ainsi de meilleures performances et fiabilité pour nos applications.

Références :

  1. Documentation officielle de Redis : https://redis.io/documentation
  2. Bibliothèque client Go Redis : https://github.com/go-redis/redis

Ce qui précède est le contenu complet de l'article , j'espère que cela sera utile à tout le monde. Merci d'avoir lu!

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment construire le mode Cluster Redis Comment construire le mode Cluster Redis Apr 10, 2025 pm 10:15 PM

Le mode Redis Cluster déploie les instances Redis sur plusieurs serveurs grâce à la rupture, à l'amélioration de l'évolutivité et de la disponibilité. Les étapes de construction sont les suivantes: Créez des instances de redis étranges avec différents ports; Créer 3 instances Sentinel, Moniteur Redis Instances et basculement; Configurer les fichiers de configuration Sentinel, ajouter des informations d'instance Redis de surveillance et des paramètres de basculement; Configurer les fichiers de configuration d'instance Redis, activer le mode de cluster et spécifier le chemin du fichier d'informations de cluster; Créer un fichier nœuds.conf, contenant des informations de chaque instance redis; Démarrez le cluster, exécutez la commande CREATE pour créer un cluster et spécifiez le nombre de répliques; Connectez-vous au cluster pour exécuter la commande d'informations de cluster pour vérifier l'état du cluster; faire

Comment effacer les données redis Comment effacer les données redis Apr 10, 2025 pm 10:06 PM

Comment effacer les données Redis: utilisez la commande flushall pour effacer toutes les valeurs de clé. Utilisez la commande flushdb pour effacer la valeur clé de la base de données actuellement sélectionnée. Utilisez SELECT pour commuter les bases de données, puis utilisez FlushDB pour effacer plusieurs bases de données. Utilisez la commande del pour supprimer une clé spécifique. Utilisez l'outil Redis-CLI pour effacer les données.

Comment lire la file d'attente redis Comment lire la file d'attente redis Apr 10, 2025 pm 10:12 PM

Pour lire une file d'attente à partir de Redis, vous devez obtenir le nom de la file d'attente, lire les éléments à l'aide de la commande LPOP et traiter la file d'attente vide. Les étapes spécifiques sont les suivantes: Obtenez le nom de la file d'attente: Nommez-le avec le préfixe de "Fitre:" tel que "Fitre: My-Quyue". Utilisez la commande LPOP: éjectez l'élément de la tête de la file d'attente et renvoyez sa valeur, telle que la file d'attente LPOP: My-Queue. Traitement des files d'attente vides: si la file d'attente est vide, LPOP renvoie NIL et vous pouvez vérifier si la file d'attente existe avant de lire l'élément.

Comment utiliser la ligne de commande redis Comment utiliser la ligne de commande redis Apr 10, 2025 pm 10:18 PM

Utilisez l'outil de ligne de commande redis (Redis-CLI) pour gérer et utiliser Redis via les étapes suivantes: Connectez-vous au serveur, spécifiez l'adresse et le port. Envoyez des commandes au serveur à l'aide du nom et des paramètres de commande. Utilisez la commande d'aide pour afficher les informations d'aide pour une commande spécifique. Utilisez la commande QUIT pour quitter l'outil de ligne de commande.

Comment configurer le temps d'exécution du script LUA dans Centos Redis Comment configurer le temps d'exécution du script LUA dans Centos Redis Apr 14, 2025 pm 02:12 PM

Sur CentOS Systems, vous pouvez limiter le temps d'exécution des scripts LUA en modifiant les fichiers de configuration Redis ou en utilisant des commandes Redis pour empêcher les scripts malveillants de consommer trop de ressources. Méthode 1: Modifiez le fichier de configuration Redis et localisez le fichier de configuration Redis: le fichier de configuration redis est généralement situé dans /etc/redis/redis.conf. Edit Fichier de configuration: Ouvrez le fichier de configuration à l'aide d'un éditeur de texte (tel que VI ou NANO): Sudovi / etc / redis / redis.conf Définissez le délai d'exécution du script LUA: Ajouter ou modifier les lignes suivantes dans le fichier de configuration pour définir le temps d'exécution maximal du script LUA (unité: millisecondes)

Comment définir la politique d'expiration redis Comment définir la politique d'expiration redis Apr 10, 2025 pm 10:03 PM

Il existe deux types de stratégies d'expiration de données redis: la suppression périodique: analyse périodique pour supprimer la clé expirée, qui peut être définie via des paramètres d'expiration-temps-transport et des paramètres d'expiration-temps-transparence. Suppression paresseuse: vérifiez les clés expirées de suppression uniquement lorsque les clés sont lues ou écrites. Ils peuvent être définis à travers des paramètres Lazyfree-Lazy-Deviction, Lazyfree-Lazy-Expire, Lazyfree-Lazy-User-Del.

Optimisation des performances postgresql sous Debian Optimisation des performances postgresql sous Debian Apr 12, 2025 pm 08:18 PM

Pour améliorer les performances de la base de données PostgreSQL dans Debian Systems, il est nécessaire de considérer de manière approfondie le matériel, la configuration, l'indexation, la requête et d'autres aspects. Les stratégies suivantes peuvent optimiser efficacement les performances de la base de données: 1. Extension de mémoire d'optimisation des ressources matérielles: la mémoire adéquate est cruciale pour cacher les données et les index. Stockage à grande vitesse: l'utilisation de disques SSD SSD peut considérablement améliorer les performances d'E / S. Processeur multi-core: utilisez pleinement les processeurs multi-core pour implémenter le traitement des requêtes parallèles. 2. Paramètre de base de données Tuning Shared_Buffers: Selon le réglage de la taille de la mémoire du système, il est recommandé de le définir à 25% -40% de la mémoire système. work_mem: contrôle la mémoire des opérations de tri et de hachage, généralement définies sur 64 Mo à 256m

Comment optimiser les performances de Debian Readdir Comment optimiser les performances de Debian Readdir Apr 13, 2025 am 08:48 AM

Dans Debian Systems, les appels du système ReadDir sont utilisés pour lire le contenu des répertoires. Si ses performances ne sont pas bonnes, essayez la stratégie d'optimisation suivante: simplifiez le nombre de fichiers d'annuaire: divisez les grands répertoires en plusieurs petits répertoires autant que possible, en réduisant le nombre d'éléments traités par appel ReadDir. Activer la mise en cache de contenu du répertoire: construire un mécanisme de cache, mettre à jour le cache régulièrement ou lorsque le contenu du répertoire change et réduire les appels fréquents à Readdir. Les caches de mémoire (telles que Memcached ou Redis) ou les caches locales (telles que les fichiers ou les bases de données) peuvent être prises en compte. Adoptez une structure de données efficace: si vous implémentez vous-même la traversée du répertoire, sélectionnez des structures de données plus efficaces (telles que les tables de hachage au lieu de la recherche linéaire) pour stocker et accéder aux informations du répertoire

See all articles