Ce projet est une application microservices construite avec Node.js et React. Il est conçu pour être déployé sur Kubernetes.
- Introduction
- Table des matières
- Architecture
- Chemins d'Ingress
- Noms de Services Kubernetes
- Ports des Services
- Prérequis
- Installation
- Déploiement
L'application est composée des services suivants :
- Client : Interface utilisateur construite avec React.
- Posts : Service pour la gestion des posts.
- Comments : Service pour la gestion des commentaires.
- Query : Service pour la gestion des requêtes.
- Moderation : Service pour la modération des commentaires.
- Event Bus : Service pour la gestion des événements entre les services.
-
/posts/create: Dirigé vers le serviceposts-clusterip-srvsur le port 4000.- Utilisé pour créer de nouveaux posts.
-
/posts: Dirigé vers le servicequery-srvsur le port 4002.- Utilisé pour récupérer la liste des posts existants.
-
/posts/?(.*)/comments: Dirigé vers le servicecomments-srvsur le port 4001.- Utilisé pour créer ou récupérer les commentaires associés à un post spécifique.
-
/?(.*): Dirigé vers le serviceclient-srvsur le port 3000.- Utilisé pour accéder à l'interface utilisateur.
Assurez-vous que les noms de services dans vos fichiers de déploiement Kubernetes correspondent aux noms de services utilisés dans le code de l'application. Voici les noms de services attendus :
- client-srv: Service pour l'interface utilisateur.
- posts-clusterip-srv: Service pour la gestion des posts.
- query-srv: Service pour la gestion des requêtes.
- comments-srv: Service pour la gestion des commentaires.
- moderation-srv: Service pour la modération des commentaires.
- event-bus-srv: Service pour la gestion des événements entre les services.
Si vous modifiez ces noms, assurez-vous également de mettre à jour les références correspondantes dans le code de l'application.
Chaque service écoute sur un port spécifique. Assurez-vous que ces ports sont correctement configurés dans vos fichiers de déploiement Kubernetes et dans tout autre outil de gestion des conteneurs que vous pourriez utiliser. Voici les ports attendus pour chaque service :
- client-srv: Écoute sur le port 3000.
- posts-clusterip-srv: Écoute sur le port 4000.
- query-srv: Écoute sur le port 4002.
- comments-srv: Écoute sur le port 4001.
- moderation-srv: Écoute sur le port 4003.
- event-bus-srv: Écoute sur le port 4005.
Si vous modifiez ces ports, assurez-vous également de mettre à jour les références correspondantes dans le code de l'application et les fichiers de configuration Kubernetes.
- Node.js
- Docker
- Kubernetes
-
Clonez ce dépôt :
git clone https://github.com/Mossbaddi/Pojet_fil_rouge.git
-
Installez les dépendances pour chaque service :
cd client && npm install cd ../posts && npm install # Répétez pour tous les services
-
Construisez les images Docker pour chaque service :
docker build -t client ./client docker build -t posts ./posts # Répétez pour tous les servicesLe projet est basé sur l'image node:alpine
-
Déployez les services sur Kubernetes :
kubectl apply -f k8s/