


Une brève discussion sur la façon d'effectuer des tâches planifiées dans Nodejs
Cet article vous présentera comment implémenter des tâches planifiées dans Node J'espère qu'il vous sera utile !
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Node.js est un environnement d'exécution JavaScript côté serveur, tandis que Vue.js est un framework JavaScript côté client permettant de créer des interfaces utilisateur interactives. Node.js est utilisé pour le développement côté serveur, comme le développement d'API de service back-end et le traitement des données, tandis que Vue.js est utilisé pour le développement côté client, comme les applications monopage et les interfaces utilisateur réactives.

Node.js peut être utilisé comme framework backend car il offre des fonctionnalités telles que des performances élevées, l'évolutivité, la prise en charge multiplateforme, un écosystème riche et une facilité de développement.

Pour vous connecter à une base de données MySQL, vous devez suivre ces étapes : Installez le pilote mysql2. Utilisez mysql2.createConnection() pour créer un objet de connexion contenant l'adresse de l'hôte, le port, le nom d'utilisateur, le mot de passe et le nom de la base de données. Utilisez connection.query() pour effectuer des requêtes. Enfin, utilisez connection.end() pour mettre fin à la connexion.

Il existe deux fichiers liés à npm dans le répertoire d'installation de Node.js : npm et npm.cmd. Les différences sont les suivantes : différentes extensions : npm est un fichier exécutable et npm.cmd est un raccourci de fenêtre de commande. Utilisateurs Windows : npm.cmd peut être utilisé à partir de l'invite de commande, npm ne peut être exécuté qu'à partir de la ligne de commande. Compatibilité : npm.cmd est spécifique aux systèmes Windows, npm est disponible multiplateforme. Recommandations d'utilisation : les utilisateurs Windows utilisent npm.cmd, les autres systèmes d'exploitation utilisent npm.

Les variables globales suivantes existent dans Node.js : Objet global : global Module principal : processus, console, nécessiter Variables d'environnement d'exécution : __dirname, __filename, __line, __column Constantes : undefined, null, NaN, Infinity, -Infinity

Les principales différences entre Node.js et Java résident dans la conception et les fonctionnalités : Piloté par les événements ou piloté par les threads : Node.js est piloté par les événements et Java est piloté par les threads. Monothread ou multithread : Node.js utilise une boucle d'événements monothread et Java utilise une architecture multithread. Environnement d'exécution : Node.js s'exécute sur le moteur JavaScript V8, tandis que Java s'exécute sur la JVM. Syntaxe : Node.js utilise la syntaxe JavaScript, tandis que Java utilise la syntaxe Java. Objectif : Node.js convient aux tâches gourmandes en E/S, tandis que Java convient aux applications de grande entreprise.

Oui, Node.js est un langage de développement backend. Il est utilisé pour le développement back-end, notamment la gestion de la logique métier côté serveur, la gestion des connexions à la base de données et la fourniture d'API.

Étapes de déploiement de serveur pour un projet Node.js : Préparez l'environnement de déploiement : obtenez l'accès au serveur, installez Node.js, configurez un référentiel Git. Créez l'application : utilisez npm run build pour générer du code et des dépendances déployables. Téléchargez le code sur le serveur : via Git ou File Transfer Protocol. Installer les dépendances : connectez-vous en SSH au serveur et installez les dépendances de l'application à l'aide de npm install. Démarrez l'application : utilisez une commande telle que node index.js pour démarrer l'application ou utilisez un gestionnaire de processus tel que pm2. Configurer un proxy inverse (facultatif) : utilisez un proxy inverse tel que Nginx ou Apache pour acheminer le trafic vers votre application
