Architecture du système d'alerte


10

Je voudrais créer un système qui gère les messages d'alerte de divers programmes et peut traiter ces alertes par e-mail auprès des consommateurs en aval. Tout cela serait contenu sur un seul réseau interne.

Je pense que je veux que l'architecture de base ressemble à ceci:entrez la description de l'image ici

La principale préoccupation que j'ai actuellement est le bit "Message Handler", qui sera mon "sort-of-API". Je veux que tous les composants de ce système envoient des données à l'API, qui gère toutes les écritures dans la base de données. Je pense que cette approche est plus facile car elle simplifie la sécurité et me permet de contenir un grand nombre des requêtes DB les plus compliquées dans un seul programme.

Le souci est que je veux que ce soit indépendant du langage - ce qui signifie que tout code devrait être capable d'envoyer des messages à mon gestionnaire - qui les interprétera. J'espère le faire via des fichiers plats JSON - ou via des appels REST au programme (ce qui donne de la flexibilité aux applications en aval).

Ma question est-

Dois-je me soucier du gestionnaire de messages - ou ajouterait-il de la simplicité pour permettre uniquement l'accès direct à la base de données aux applications en aval, ainsi qu'aux deux autres composants (Management Console et Alert Manager)?

De cette façon, ils peuvent insérer l'alerte qu'ils souhaitent - tant que l'INSERT dans la / les table (s) DB est valide.

Je ne suis pas un concepteur de logiciels de métier alors excusez-moi - je veux juste un projet à faire pendant mon temps libre.

Réponses:


4

Avez-vous étudié AMQP (Advanced Message Queuing Protocol: https://www.rabbitmq.com/protocol.html )?

RabbitMQ est un outil génial pour quelque chose comme ça, je pense (il y en a aussi d'autres, MSMQ, Azure / AWS, etc.). Non seulement vous obtenez un gestionnaire de messages indépendant de la langue (simple "envoyer le message au serveur de messages avec des données json"), vous détachez le traitement des messages en aval et le rendez bien isolé. Exécutez un service de messagerie qui traite les messages entrants de la ou des files d'attente dont vous avez besoin et crachez vos notifications.

L'une des raisons pour lesquelles j'aime vraiment utiliser AMQP est que vous commencez comme si vous étiez maintenant avec une solution maison, mais réalisez que vous devez gérer les messages légèrement différemment selon le type, vers qui il doit aller, etc. , vous finissez donc par créer votre propre implémentation AMQP.

Que faites-vous si un message doit être envoyé à 5 destinataires différents? Que se passe-t-il si vous avez un message qui doit être tourné sur un certain nombre de processeurs (pensez aux tâches de longue durée et au nombre X de processeurs simultanés, où vous pouvez faire un tour de table des messages d'un type spécifique). Et si le message devait aller à une personne, mais s'il n'est pas disponible / en ligne, il devrait aller à une autre? L'AMQP gère déjà tout cela (très bien!), Avec une très bonne catégorisation, des files d'attente, des canaux, une persistance durable, toutes sortes de fonctionnalités.

Voici un aperçu de base des scénarios qu'il peut gérer (notez que ce n'est pas spécifique à RabbitMQ: c'est une chose AMQP, mais RabbitMQ arrive à bien l'expliquer) - https://www.rabbitmq.com/getstarted.html


J'ai déjà vu RabbitMQ implémenté pour d'autres logiciels - semblait toujours intéressant (sinon un peu compliqué). Je vais y jeter un œil! Je pense que j'ai hésité au début parce que je voulais beaucoup de flexibilité pour offrir aux expéditeurs de données. Donc, s'il est difficile d'implémenter un appel REST sur un Powershell ou Javascript existant, ou que le ciel interdise une application VB6, ils peuvent généralement sortir assez facilement dans un fichier plat. Mais pouvoir remplacer une grande partie de la gestion des messages réduirait le temps et les efforts à coup sûr!
Christopher

2
J'étais un peu intimidé quand je suis entré dans RabbitMQ, mais après un week-end d'étude, c'était comme wow, c'est vraiment vraiment, vraiment sympa, et maintenant que je comprends ce que je regarde, c'est vraiment très simple
jleach

J'aime l'idée d'AMQP, mais la façon dont RabbitMQ gère les API clientes pour chaque langue va à l'encontre de l'objectif global d'utiliser un protocole indépendant de la langue. Que se passe-t-il si j'ai un client qui exécute une langue qui n'a pas d'API prise en charge écrite pour cela? Certaines de ces fonctionnalités sont vraiment agréables ... mais exagérées quand tout ce que je dois faire est d'obtenir 1 message du point A au point B, sans rien entre les deux.
Christopher

Je pensais à gifler une API de repos rapide par-dessus, qui couvrirait votre inquiétude agnostique, mais j'ai convenu que si vous n'avez jamais besoin d'aucune des fonctionnalités qu'AMQP offre, ce serait exagéré (excuses si je vous avais exécuté un sauvage) goose chase on it ...)
jleach

Ouais - une API REST rapide pour le couvrir fonctionnerait .. mais alors je ferais aussi bien de créer une API REST de ma propre initiative. Et aucune excuse requise - c'est une excellente technologie et l'apprentissage est essentiel pour progresser :) sinon maintenant - je suis sûr que cela sera utile à l'avenir.
Christopher

3

Question très bien cadrée!

Ainsi, toutes les décisions architecturales impliquent des compromis. Si vous êtes curieux de discuter des compromis, modifiez peut-être votre question dans ce sens. Au lieu de cela, puisque la question demande simplement une position, je prendrai le parti de plaider en faveur du MessageHandler. Je vais aller plus loin pour suggérer de ne PAS inclure de base de données - du moins pas une base de données SQL, du moins de ne pas commencer. Demandez simplement au MessageHandler d'enregistrer le JSON dans le système de fichiers, par exemple un répertoire par heure de réception des alertes (en fonction du volume, bien sûr), et disposez de l'API lorsque le gestionnaire d'alertes l'interroge, parcourez simplement les 2 derniers répertoires de des alertes pour décider quels e-mails envoyer (en fonction de la priorité, bien sûr).

Il y a une tonne de bonnes choses à mâcher dans ce problème, et garder une base de données hors de l'image dès les premiers stades supprimera beaucoup de bruit incident et de résolution de problème inutile. Bien sûr, vous avez peut-être un amour caché de créer des modèles de données relationnelles et rêvez d'écrire du SQL. Dans ce cas, cette réponse est totalement fausse. Mais de manière générale, même les bases de données les plus agiles sont de terribles plates-formes d'application, et elles ne sont incluses dans les systèmes que parce qu'elles sont spécialistes de la durabilité et des requêtes indexées.

Bonne chance!


1
J'aime juste la possibilité de contrôler les groupes de messagerie, les membres et diverses autres choses intéressantes sur l'utilisation d'une base de données relationnelle. La conception de la base de données est vraiment ce avec quoi j'ai commencé dans le projet - donc je n'ai même jamais pensé à la supprimer. Merci pour cette contribution et ce point de vue !!
Christopher

Je le savais! :) Comprendre ce que vous cherchez vraiment à tirer de quelque chose est la chose la plus importante. À votre santé!
Jonah Benton
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.