Maison >interface Web >js tutoriel >Une brève discussion sur la façon d'effectuer des tâches planifiées dans Nodejs

Une brève discussion sur la façon d'effectuer des tâches planifiées dans Nodejs

青灯夜游
青灯夜游avant
2021-10-25 09:49:423040parcourir

Cet article vous présentera comment implémenter des tâches planifiées dans Node J'espère qu'il vous sera utile !

Une brève discussion sur la façon d'effectuer des tâches planifiées dans Nodejs

Actuellement, nous avons rencontré une telle demande. Chaque utilisateur peut personnaliser le push programmé. La configuration temporelle de la tâche planifiée est configurée par l'utilisateur et peut être modifiée à tout moment, au lieu du réglage traditionnel du serveur par l'heure. exécuter la tâche planifiée. [Apprentissage recommandé : "Tutoriel Nodejs"]

Si le cycle des tâches planifiées est connu, alors les tâches planifiées Linux Crontab peuvent être implémentées. Il existe déjà des solutions relativement matures dans node. Ci-dessous, je présenterai la solution de tâches planifiées Node que j'ai apprise sur moi-même.

La tâche planifiée de planification fournie par le framework egg

egg est le framework d'application Node d'Alibaba au niveau de l'entreprise. Il fournit un ensemble de mécanismes permettant aux développeurs d'écrire des tâches planifiées avec élégance. Pour plus de détails, veuillez vous référer à la documentation officielle : . https://eggjs .org/zh-cn/basics/schedule.html , l'utilisation spécifique ne sera pas détaillée ici, mais son utilisation en configuration sera brièvement discutée.

1. Les tâches planifiées statiques, c'est-à-dire les cycles planifiés, ont une logique de traitement codée en dur.

2. Configurez dynamiquement les tâches planifiées, ce qui est relativement plus flexible. Les développeurs peuvent contrôler le cycle des tâches planifiées via des fichiers de configuration.

3. Déclenchez manuellement les tâches planifiées via le code. Nous pouvons déterminer s'il convient de déclencher des tâches planifiées en fonction d'une certaine logique.

À partir des trois points ci-dessus, les tâches planifiées fournies par egg ne peuvent pas répondre à nos besoins pour les utilisateurs de configurer eux-mêmes la période de synchronisation, nous ne pouvons donc rechercher d'autres solutions qu'en interrogeant les données, nous avons constaté que la bibliothèque node-schedule également. fournit la fonction de tâches planifiées.

node-schedule

Après avoir parcouru la documentation de node-schudule https://www.npmjs.com/package/node-schedule, son utilisation est la suivante :

const schedule = require('node-schedule');

const job = schedule.scheduleJob('42 * * * *', function(){
  console.log('The answer to life, the universe, and everything!');
});

Oui, il supporte depuis Defining le cycle de synchronisation peut répondre à nos besoins et peut être notre choix. Bien !

En continuant à parcourir les articles d'utilisation d'autres développeurs, j'ai trouvé un enregistrement de problèmes liés à node-schedule. 2 fois. Pour des questions spécifiques, veuillez consulter le texte original : https://cnodejs.org/topic/5b58414b8d66b90b2b7384a7. Il s'agit d'un problème de faible probabilité. Nous ne l'avons pas vérifié. En raison de nos besoins, le minuteur est exécuté deux fois, ce qui n'a aucun impact sur nos résultats, ce n'est donc pas un obstacle qui nous empêche de l'utiliser. Testez les bugs.

Écrit à la fin

Enfin, voici un résumé des solutions de tâches planifiées de notre propre projet. Les étudiants qui ne sont pas intéressés peuvent l'ignorer.

Notre backend utilise le framework egg, notre solution finale consiste donc à ajouter un timer de nœud-schdule au processus d'agent. Le timer de l'utilisateur sera exécuté de manière synchrone dans le processus d'agent. À l'heure actuelle, notre nombre d'utilisateurs n'est pas important. , je ne pense qu'à cette solution pour le moment, et le backend pourra être déployé de manière distribuée après une augmentation future du volume.

Ce sera un problème, et l'exécuter en un seul processus sera également un problème si le volume est important, et Egg lui-même ne recommande pas de faire trop de choses liées à l'entreprise dans le processus d'agent. Une autre chose importante est que l'agent est un processus auxiliaire. Certains travaux publics sont terminés dans l'agent. Si une erreur non détectée se produit, l'agent ne se fermera pas et ne redémarrera pas, le traitement de tolérance aux pannes doit donc être effectué et bien effectué.

Pour plus de connaissances sur la programmation, veuillez visiter : Vidéos de programmation ! !

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer