Maison base de données Redis Comment Redis implémente la fonction de file d'attente de messages

Comment Redis implémente la fonction de file d'attente de messages

Nov 07, 2023 pm 04:49 PM
redis 消息队列 实现

Comment Redis implémente la fonction de file dattente de messages

Comment Redis implémente la fonction de file d'attente de messages

Avec le développement d'Internet, les files d'attente de messages deviennent de plus en plus importantes dans les systèmes distribués. Les files d'attente de messages permettent à différentes applications de transmettre et de traiter des messages via une communication asynchrone, améliorant ainsi l'évolutivité et la fiabilité du système. En tant que base de données en mémoire rapide, fiable et flexible, Redis peut également être utilisée pour implémenter des fonctions de file d'attente de messages. Cet article présentera comment Redis implémente la fonction de file d'attente de messages et fournira quelques exemples de code spécifiques.

1. Utilisez la structure de données Redis List

Redis fournit une variété de types de données, tels que String, Hash, Set, Sorted Set, etc., mais lors de l'implémentation de la fonction de file d'attente de messages, la structure de données la plus couramment utilisée est List. . La structure de données List stocke les données dans l'ordre premier entré, premier sorti (FIFO) et convient très bien comme file d'attente de messages. Nous pouvons stocker le message sous la forme d'une chaîne à la fin de la liste, et le consommateur reçoit le message de la tête de la liste. Voici un exemple de code utilisant List pour implémenter une file d'attente de messages :

// Code producteur
import redis.clients.jedis.Jedis;

public class Producer {

public static void main(String[] args) {
    Jedis jedis = new Jedis("localhost");
    jedis.lpush("message_queue", "hello");
    jedis.lpush("message_queue", "world");
    jedis.lpush("message_queue", "redis");
    jedis.close();
}
Copier après la connexion

}

// Code consommateur
import redis. clients .jedis.Jedis;

public class Consumer {

public static void main(String[] args) {
    Jedis jedis = new Jedis("localhost");
    while (true) {
        List<String> messages = jedis.brpop(0, "message_queue");
        String message = messages.get(1);
        System.out.println("Received message: " + message);
    }
}
Copier après la connexion

}

Dans cet exemple, le producteur stocke les messages dans une liste nommée "message_queue" à tour de rôle, et le consommateur appelle brpop</code >Le La commande récupère le message de la tête de la liste. Lorsque la file d'attente des messages est vide, la commande <code>brpop se bloque jusqu'à ce qu'un nouveau message arrive. brpop命令从List的头部获取消息。当消息队列为空时,brpop命令会阻塞直到有新的消息到达。

二、实现消息的发布和订阅

除了使用List来实现消息队列功能,Redis还提供了发布(Publish)和订阅(Subscribe)的功能。发布者将消息发布到指定的频道上,订阅者通过订阅相应的频道来接收消息。以下是使用发布和订阅实现消息队列的代码示例:

// 发布者代码
import redis.clients.jedis.Jedis;

public class Publisher {

public static void main(String[] args) {
    Jedis jedis = new Jedis("localhost");
    jedis.publish("message_channel", "hello");
    jedis.publish("message_channel", "world");
    jedis.publish("message_channel", "redis");
    jedis.close();
}
Copier après la connexion

}

// 订阅者代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPubSub;

public class Subscriber {

public static void main(String[] args) {
    Jedis jedis = new Jedis("localhost");
    jedis.subscribe(new JedisPubSub() {
        @Override
        public void onMessage(String channel, String message) {
            System.out.println("Received message: " + message);
        }
    }, "message_channel");
}
Copier après la connexion

}

运行这些代码,可以看到订阅者会实时地接收到发布者发送的消息。

三、使用Redis的消息发布/订阅模式

除了上述的发布/订阅功能,Redis还提供了消息发布/订阅模式。在消息发布/订阅模式中,可以有多个订阅者同时接收并处理相同的消息。以下是使用消息发布/订阅模式实现消息队列的代码示例:

// 发布者代码
import redis.clients.jedis.Jedis;

public class Publisher {

public static void main(String[] args) {
    Jedis jedis = new Jedis("localhost");
    jedis.publish("message_pattern.*", "hello");
    jedis.publish("message_pattern.*", "world");
    jedis.publish("message_pattern.*", "redis");
    jedis.close();
}
Copier après la connexion

}

// 订阅者代码
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPubSub;

public class Subscriber {

public static void main(String[] args) {
    Jedis jedis = new Jedis("localhost");
    jedis.psubscribe(new JedisPubSub() {
        @Override
        public void onMessage(String channel, String message) {
            System.out.println("Received message: " + message);
        }
    }, "message_pattern.*");
}
Copier après la connexion

}

在这个例子中,发布者将消息发布到名为"message_pattern.*"的频道上,而订阅者使用psubscribe

2. Implémenter la publication et l'abonnement des messages

En plus d'utiliser List pour implémenter la fonction de file d'attente de messages, Redis fournit également des fonctions de publication (Publier) et d'abonnement (S'abonner). L'éditeur publie le message sur le canal spécifié et l'abonné reçoit le message en s'abonnant au canal correspondant. Voici un exemple de code pour implémenter une file d'attente de messages à l'aide de la publication et de l'abonnement :

// Code de l'éditeur

import redis.clients.jedis.Jedis

    public class Publisher {
  • rrreee
  • }
  • // Code de l'abonné
import ; redis .clients.jedis.Jedis;🎜import redis.clients.jedis.JedisPubSub;🎜🎜public class Subscriber {🎜rrreee🎜}🎜🎜Exécutez ces codes et vous pourrez voir que l'abonné recevra le message envoyé par l'éditeur en réel temps. 🎜🎜3. Utilisez le mode de publication/abonnement de messages de Redis🎜🎜En plus des fonctions de publication/abonnement ci-dessus, Redis propose également un mode de publication/abonnement de messages. Dans le modèle de publication/abonnement de message, plusieurs abonnés peuvent recevoir et traiter le même message en même temps. Voici un exemple de code pour implémenter une file d'attente de messages à l'aide du modèle de publication/abonnement de messages : 🎜🎜// Code de l'éditeur 🎜import redis.clients.jedis.Jedis 🎜🎜public class Publisher {🎜rrreee🎜}🎜🎜// Abonné; code 🎜 import redis.clients.jedis.Jedis;🎜import redis.clients.jedis.JedisPubSub;🎜🎜public class Subscriber {🎜rrreee🎜}🎜🎜Dans cet exemple, l'éditeur publie le message dans un nom nommé "message_pattern.*" chaîne et les abonnés utilisent la commande psubscribe pour s'abonner à toutes les chaînes commençant par "message_pattern.". Ainsi, s'il existe d'autres chaînes commençant par "message_pattern.", les abonnés pourront également recevoir les messages correspondants. 🎜🎜Conclusion : 🎜🎜Grâce à la structure de données List de Redis, à la fonction de publication/abonnement et au mode de publication/abonnement aux messages, nous pouvons facilement implémenter la fonction de file d'attente de messages. Cependant, il convient de noter que Redis est une base de données en mémoire. Si la quantité de messages est trop importante, elle peut occuper une grande quantité de mémoire. Par conséquent, lors de l'utilisation de Redis comme file d'attente de messages, une configuration et une optimisation raisonnables doivent être effectuées. en fonction de la situation réelle. Dans le même temps, afin de garantir la fiabilité du message, une logique supplémentaire doit être traitée du côté du consommateur, comme le mécanisme de confirmation du message. 🎜🎜Matériaux de référence : 🎜🎜🎜Documentation officielle de Redis : https://redis.io/🎜🎜Code source de Redis : https://github.com/redis/redis🎜🎜

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

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 implémenter le redis sous-jacent Comment implémenter le redis sous-jacent Apr 10, 2025 pm 07:21 PM

Redis utilise des tables de hachage pour stocker les données et prend en charge les structures de données telles que les chaînes, les listes, les tables de hachage, les collections et les collections ordonnées. Redis persiste les données via des instantanés (RDB) et ajoutez les mécanismes d'écriture uniquement (AOF). Redis utilise la réplication maître-esclave pour améliorer la disponibilité des données. Redis utilise une boucle d'événement unique pour gérer les connexions et les commandes pour assurer l'atomicité et la cohérence des données. Redis définit le temps d'expiration de la clé et utilise le mécanisme de suppression paresseux pour supprimer la clé d'expiration.

Comment afficher le numéro de version de redis Comment afficher le numéro de version de redis Apr 10, 2025 pm 05:57 PM

Pour afficher le numéro de version redis, vous pouvez utiliser les trois méthodes suivantes: (1) Entrez la commande Info, (2) Démarrez le serveur avec l'option - Version et (3) afficher le fichier de configuration.

Que faire si redis-server ne peut être trouvé Que faire si redis-server ne peut être trouvé Apr 10, 2025 pm 06:54 PM

Étapes pour résoudre le problème que Redis-Server ne peut pas trouver: Vérifiez l'installation pour vous assurer que Redis est installé correctement; Définissez les variables d'environnement redis_host et redis_port; Démarrer le serveur Redis Redis-Server; Vérifiez si le serveur exécute Redis-Cli Ping.

Comment le cluster redis est-il implémenté Comment le cluster redis est-il implémenté Apr 10, 2025 pm 05:27 PM

Le cluster Redis est un modèle de déploiement distribué qui permet une expansion horizontale des instances Redis, et est implémentée via la communication inter-nœuds, l'espace clé de la division des emplacements de hachage, l'élection du nœud, la réplication maître-esclave et la redirection de commande: communication inter-nœuds: la communication du réseau virtuel est réalisée via le bus de cluster. Slot de hachage: divise l'espace clé en emplacements de hachage pour déterminer le nœud responsable de la clé. Élection du nœud: au moins trois nœuds maîtres sont nécessaires et un seul nœud maître actif est assuré par le mécanisme électoral. Réplication maître-esclave: le nœud maître est responsable de la rédaction de demandes, et le nœud esclave est responsable des demandes de lecture et de la réplication des données. Redirection de commande: le client se connecte au nœud responsable de la clé et le nœud redirige les demandes incorrectes. Dépannage: détection des défauts, marquer la ligne et re

Comment la clé est-elle unique pour Redis Query Comment la clé est-elle unique pour Redis Query Apr 10, 2025 pm 07:03 PM

Redis utilise cinq stratégies pour assurer le caractère unique des clés: 1. Séparation des espaces de noms; 2. Structure de données de hachage; 3. Définir la structure des données; 4. Caractères spéciaux des touches de chaîne; 5. Vérification du script LUA. Le choix de stratégies spécifiques dépend de l'organisation des données, des performances et des exigences d'évolutivité.

Comment afficher toutes les clés dans Redis Comment afficher toutes les clés dans Redis Apr 10, 2025 pm 07:15 PM

Pour afficher toutes les touches dans Redis, il existe trois façons: utilisez la commande Keys pour retourner toutes les clés qui correspondent au modèle spécifié; Utilisez la commande SCAN pour itérer les touches et renvoyez un ensemble de clés; Utilisez la commande info pour obtenir le nombre total de clés.

Comment utiliser redis zset Comment utiliser redis zset Apr 10, 2025 pm 07:27 PM

Les ensembles commandés par Redis (ZSETS) sont utilisés pour stocker des éléments commandés et trier par des scores associés. Les étapes à utiliser ZSET incluent: 1. Créer un ZSET; 2. Ajouter un membre; 3. Obtenez un score de membre; 4. Obtenez un classement; 5. Obtenez un membre dans la gamme de classement; 6. Supprimer un membre; 7. Obtenez le nombre d'éléments; 8. Obtenez le nombre de membres dans la plage de score.

See all articles