Maison  >  Article  >  développement back-end  >  Comment connecter Redis à Golang

Comment connecter Redis à Golang

WBOY
WBOYoriginal
2023-05-10 10:57:06766parcourir

Redis est un système de stockage de données clé-valeur basé sur la mémoire open source qui prend en charge une variété de structures de données et de mécanismes de sauvegarde. Il est largement utilisé dans le cache, les files d'attente de messages, les compteurs en temps réel, la gestion de sessions et d'autres domaines. Golang est un langage de programmation open source présentant les caractéristiques de hautes performances, de typage fort, de simplicité et de lisibilité, ainsi que de sécurité simultanée. Il est progressivement devenu un langage populaire dans le cloud computing, la programmation réseau, les systèmes distribués et d'autres domaines. Cet article expliquera comment connecter Redis à Golang et effectuer des opérations de lecture et d'écriture de données.

  1. Installez Redis et Go Redis client

Vous devez d'abord installer Redis et démarrer le service Redis. Sous le système Ubuntu, vous pouvez utiliser la commande suivante pour installer :

sudo apt-get update
sudo apt-get install redis-server

Une fois l'installation terminée, vous pouvez utiliser la commande suivante pour démarrer le service Redis :

redis-server

En même temps, un client Redis doit être utilisé dans l'application Golang pour se connecter au service Redis. Le client Go Redis est un progiciel open source écrit par Gary Burd qui prend en charge les commandes Redis de base. Vous pouvez utiliser la commande suivante pour installer :

go get github.com/go-redis/redis

  1. Connectez-vous à Redis

Pour vous connecter au service Redis dans une application Go, vous devez spécifier l'adresse, le port numéro et mot de passe du serveur Redis (le cas échéant). Vous pouvez utiliser le code suivant pour vous connecter au service Redis :

import "github.com/go-redis/redis"

func main() {
client := redis.NewClient(&redis.Options{

  Addr:     "localhost:6379",
  Password: "", // no password set
  DB:       0,  // use default DB

} )

pong, err := client.Ping().Result()
fmt.Println(pong, err)
}

Un objet client Redis est créé ici et l'adresse du serveur Redis est spécifiée comme localhost, le numéro de port est 6379 et le mot de passe est vide, utilisez la base de données par défaut. Appelez ensuite la méthode Ping() pour tester la connexion et afficher le résultat de la connexion.

Dans les applications réelles, l'adresse, le numéro de port et le mot de passe du serveur Redis doivent être spécifiés en fonction de la situation réelle.

  1. Opérations de lecture et d'écriture de données

Ensuite, vous pouvez utiliser l'objet client Redis pour effectuer des opérations de lecture et d'écriture de données. Voici quelques commandes Redis courantes et leur implémentation dans Go :

3.1 Définition des valeurs

Vous pouvez utiliser la méthode Set() pour définir des paires clé-valeur :

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

panic(err)

}

Parmi eux, le premier paramètre est le nom de la clé, le deuxième paramètre est la valeur de la clé et le troisième paramètre est le délai d'expiration , 0 signifie aucune expiration.

3.2 Obtenir la valeur

Vous pouvez utiliser la méthode Get() pour obtenir la paire clé-valeur :

val, err := client.Get("key").Result()
if err != nil {

panic(err)

}
fmt .Println("key", val)

Parmi eux, le premier paramètre est le nom de la clé, la valeur de retour est la valeur de la clé et nil est renvoyé si la clé n'existe pas.

3.3 Auto-incrémentation

Vous pouvez utiliser la méthode Incr() pour vous auto-incrémenter :

err := client.Incr("key").Err()
if err != nil {

panic(err)

}

Parmi eux, le premier Le premier paramètre est le nom de la clé, ce qui signifie auto-incrémenter la valeur de la clé.

3.4 Opérations de liste

Vous pouvez utiliser la méthode LPush() pour insérer des éléments en tête de liste :

err := client.LPush("mylist", "value1", "value2").Err()
if err != nil {

panic(err)

}

Vous pouvez utiliser la méthode LRange() pour obtenir les éléments de la liste :

vals, err := client.LRange("mylist", 0, -1).Result( )
if err != nil {

panic(err)

}
for _, val := range vals {

fmt.Println(val)

}

où, le premier paramètre est le nom de la liste, le deuxième paramètre est l'index de départ, le troisième paramètre est l'index de fin et la valeur de retour est la liste d'éléments.

3.5 Opérations sur les ensembles

Vous pouvez utiliser la méthode SAdd() pour ajouter des éléments à l'ensemble :

err := client.SAdd("myset", "value1", "value2").Err()
if err != nil {

panic(err)

}

Vous pouvez utiliser la méthode SMembers() pour obtenir les éléments définis :

vals, err := client.SMembers("myset").Result()
if err != nil {

panic(err)

}
for _ , val := range vals {

fmt.Println(val)

}

où, le premier paramètre est le nom de la collection et la valeur de retour est une liste d'éléments.

  1. Fermer la connexion

Avant de terminer le programme, la connexion du client Redis doit être fermée à temps.

err := client.Close()
if err != nil {
panic(err)
}

Après les étapes ci-dessus, vous pouvez vous connecter à Redis dans Golang et effectuer des opérations de lecture et d'écriture de données. Dans le même temps, le client Go Redis fournit également un support opérationnel plus riche, veuillez consulter la documentation officielle pour plus de détails.

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:
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