Maison base de données Redis Utilisez Redis et Node.js pour créer des services API hautement disponibles

Utilisez Redis et Node.js pour créer des services API hautement disponibles

Jul 30, 2023 pm 03:30 PM
nodejs redis 高可用

Utilisez Redis et Node.js pour créer un service API hautement disponible

Résumé : Cet article explique comment utiliser Redis et Node.js pour créer un service API hautement disponible. Les services API constituent une partie importante des applications Internet modernes, et la haute disponibilité est la clé pour garantir l'expérience utilisateur et la continuité des activités. En utilisant Redis comme cache et file d'attente de messages, et Node.js comme framework côté serveur, nous pouvons implémenter un service API évolutif, fiable et hautes performances.

1. Introduction
Le service API (Application Programming Interface) est une spécification et une interface pour la communication entre les applications. Il permet de partager des données et des fonctions entre différentes applications, offrant ainsi aux utilisateurs des services et des expériences diversifiés. Avec le développement rapide des applications Internet, les services API deviennent de plus en plus importants. Les utilisateurs attendent des applications qu'elles répondent de manière fiable aux demandes à tout moment et en tout lieu, et qu'elles fournissent des services hautes performances et haute disponibilité.

Afin d'obtenir des services API hautement disponibles, nous utiliserons Redis et Node.js. Redis est une base de données en mémoire hautes performances couramment utilisée pour la mise en cache et les files d'attente de messages. Node.js est un environnement d'exécution JavaScript basé sur le moteur Chrome V8, idéal pour créer des applications Web hautes performances.

2. Utilisez Redis comme cache
Le cache est l'un des moyens importants pour améliorer les performances et l'évolutivité de l'API. En stockant en mémoire certaines données couramment utilisées, le nombre d'accès à la base de données peut être considérablement réduit, améliorant ainsi la vitesse de réponse et les capacités de traitement simultané. Nous pouvons utiliser Redis comme base de données de cache et effacer régulièrement les caches expirés en définissant le délai d'expiration et la politique LRU (Least Récemment Utilisé).

Ce qui suit est un exemple de code qui utilise Redis comme cache :

const redis = require('redis');
const client = redis.createClient();

function getCachedData(key) {
  return new Promise((resolve, reject) => {
    client.get(key, (error, result) => {
      if (error) {
        reject(error);
      } else {
        resolve(JSON.parse(result));
      }
    });
  });
}

function cacheData(key, data, expiration) {
  client.setex(key, expiration, JSON.stringify(data));
}

// 使用示例
async function getDataFromAPI(params) {
  const cacheKey = generateCacheKey(params);
  const cachedData = await getCachedData(cacheKey);

  if (cachedData) {
    return cachedData;
  }

  const apiData = await fetchDataFromAPI(params);

  // 将数据缓存一天
  cacheData(cacheKey, apiData, 86400);

  return apiData;
}
Copier après la connexion

Dans le code ci-dessus, nous obtenons les données du cache de Redis en appelant la méthode getCachedData si les données du cache n'existent pas. , appelez La méthode fetchDataFromAPI récupère les données de l'API et les stocke dans Redis. De cette façon, lors des requêtes ultérieures, nous pouvons obtenir les données directement du cache sans accès fréquent à l'API ou à la base de données. getCachedData方法从Redis中获取缓存数据,如果不存在缓存数据,则调用fetchDataFromAPI方法从API获取数据,并将其存储在Redis中。这样,在之后的请求中,我们可以直接从缓存中获取数据,而不需要频繁地访问API或数据库。

三、使用Redis作为消息队列
消息队列是一种解耦应用程序和消息处理逻辑的方式。当请求量过大或某些任务需要异步处理时,我们可以使用消息队列来处理请求。Redis提供了一个简单而高效的消息队列,可以用于异步处理和任务调度。

以下是一个使用Redis作为消息队列的示例代码:

const redis = require('redis');
const client = redis.createClient();

function subscribe(channel, callback) {
  client.subscribe(channel, callback);
}

function publish(channel, message) {
  client.publish(channel, JSON.stringify(message));
}

// 使用示例
function handleMessage(channel, message) {
  const data = JSON.parse(message);

  // 处理消息
  // ...

  console.log('Received message:', data);
}

subscribe('api_requests', handleMessage);

// 将消息发布到队列
publish('api_requests', { "method": "GET", "path": "/api/users" });
Copier après la connexion

上述代码中,我们使用subscribe方法订阅了一个名为api_requests的频道,并指定了一个回调函数来处理接收到的消息。通过调用publish方法,我们可以将消息发送到api_requests频道,从而触发相应的处理逻辑。

四、使用Node.js构建API服务
Node.js非常适合构建高性能的API服务,它的事件驱动和非阻塞I/O模型使得它能够处理大量的并发请求。我们可以使用Express.js作为Node.js的服务端框架,它提供了简洁的API和强大的中间件支持。

以下是一个使用Node.js和Express.js构建API服务的示例代码:

const express = require('express');
const app = express();

// 处理请求
app.get('/api/users', async (req, res) => {
  const data = await getDataFromAPI(req.query);

  res.json(data);
});

// 其他API路由
// ...

app.listen(3000, () => {
  console.log('API server is running on port 3000');
});
Copier après la connexion

上述代码中,我们使用Express.js创建了一个API服务,并定义了一个处理/api/users路由的回调函数。在回调函数中,我们通过调用getDataFromAPI方法获取数据,并使用res.json

3. Utilisez Redis comme file d'attente de messages

La file d'attente de messages est un moyen de dissocier la logique de traitement des applications et des messages. Lorsque le volume de requêtes est trop important ou que certaines tâches doivent être traitées de manière asynchrone, nous pouvons utiliser la file d'attente de messages pour gérer les requêtes. Redis fournit une file d'attente de messages simple et efficace qui peut être utilisée pour le traitement asynchrone et la planification des tâches.

Ce qui suit est un exemple de code qui utilise Redis comme file d'attente de messages :

rrreee

Dans le code ci-dessus, nous utilisons la méthode subscribe pour nous abonner à un canal nommé api_requests et spécifiez Une fonction de rappel est fournie pour gérer le message reçu. En appelant la méthode publish, nous pouvons envoyer des messages au canal api_requests, déclenchant ainsi la logique de traitement correspondante.
  1. 4. Utilisez Node.js pour créer des services API
  2. Node.js est très approprié pour créer des services API hautes performances. Son modèle d'E/S basé sur les événements et non bloquant lui permet de gérer un grand nombre de requêtes simultanées. Nous pouvons utiliser Express.js comme framework côté serveur de Node.js, qui fournit une API simple et un puissant support middleware.
  3. Ce qui suit est un exemple de code pour créer un service API à l'aide de Node.js et Express.js :
  4. rrreee
  5. Dans le code ci-dessus, nous utilisons Express.js pour créer un service API et définir un gestionnaire /api/ utilisateurs La fonction de rappel de la route. Dans la fonction de rappel, nous obtenons les données en appelant la méthode getDataFromAPI et renvoyons le résultat au client à l'aide de la méthode res.json.
🎜Conclusion : 🎜En utilisant Redis comme cache et file d'attente de messages, et Node.js comme framework côté serveur, nous pouvons créer un service API évolutif, fiable et hautes performances. Les fonctions de mise en cache et de file d'attente de messages de Redis peuvent considérablement améliorer les performances et l'évolutivité de l'API, tandis que le modèle d'E/S non bloquant et piloté par les événements de Node.js lui permet de gérer un grand nombre de requêtes simultanées. En utilisant ces outils et technologies, nous pouvons obtenir des services API hautement disponibles et offrir aux utilisateurs une expérience de haute qualité et une continuité d’activité continue. 🎜🎜Références : 🎜🎜🎜Redis - https://redis.io/🎜🎜Node.js - https://nodejs.org/🎜🎜Express.js - https://expressjs.com/🎜🎜

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 commande redis Comment utiliser la commande redis Apr 10, 2025 pm 08:45 PM

L'utilisation de la directive Redis nécessite les étapes suivantes: Ouvrez le client Redis. Entrez la commande (Verbe Key Value). Fournit les paramètres requis (varie de l'instruction à l'instruction). Appuyez sur Entrée pour exécuter la commande. Redis renvoie une réponse indiquant le résultat de l'opération (généralement OK ou -err).

Comment utiliser Redis Lock Comment utiliser Redis Lock Apr 10, 2025 pm 08:39 PM

L'utilisation des opérations Redis pour verrouiller nécessite l'obtention du verrouillage via la commande setnx, puis en utilisant la commande Expire pour définir le temps d'expiration. Les étapes spécifiques sont les suivantes: (1) Utilisez la commande setnx pour essayer de définir une paire de valeurs de clé; (2) Utilisez la commande Expire pour définir le temps d'expiration du verrou; (3) Utilisez la commande del pour supprimer le verrouillage lorsque le verrouillage n'est plus nécessaire.

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