Skip to content

"Serverless AWS backend for a multi-vendor app using Node.js, S3, Lambda, SNS, and Docker. Ensures scalable storage, event-driven communication, and consistent deployment. Empowers seamless integration and scalability, supporting diverse vendor functionalities. Cloud-native solutions for a robust multi-vendor application. Feel free to explore.. ❤️

Notifications You must be signed in to change notification settings

iadarshrawat/Multi-Vendor-Microservices

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 

Repository files navigation

Multi-Vendor Microservices Application

This project is a microservices-based multi-vendor application designed to handle user management, product listing, transactions, and notifications. The architecture is scalable and uses modern cloud technologies.

Screenshot 2024-11-25 121642

Features

  1. User Service: Handles user registration, authentication, and profile management.
  2. Product Service: Manages product creation, updates, deletion, and retrieval.
  3. Transaction Service: Processes orders, payments, and transaction logs.
  4. Notification Service: Sends notifications to users via email or other channels.

Tech Stack

  • Backend: Node.js, Express.js
  • Cloud Technologies:
    • AWS CDK for infrastructure as code
    • Serverless Lambda for compute
    • SNS for notifications
    • CloudFront for content delivery
    • RDS for relational data storage
  • Database: MongoDB, RDS
  • Communication: REST APIs / RabbitMQ (for inter-service communication)
  • Containerization: Docker
  • Authentication: JWT / OAuth2

Setup

Prerequisites

  • Node.js installed
  • MongoDB instance running
  • AWS CLI configured for deployment
  • Docker installed (optional for local containerization)

Service Paths

Each service is organized into its respective folder for ease of development and deployment:

  1. User Service:

    cd services/user-service
  2. Product Service:

    cd services/product-service
  3. Transaction Service:

    cd services/transaction-service
  4. Notification Service:

    cd services/notification-service

Architecture Overview

The architecture leverages a cloud-native approach with the following components:

  1. AWS Lambda: Serverless functions for executing core service logic.
  2. SNS: Manages notifications across the application.
  3. RDS: Relational data storage for transactions and other structured data.
  4. MongoDB: Non-relational database for dynamic content such as products.
  5. CloudFront: Content delivery network for serving assets quickly.

Structural Diagram

Screenshot 2024-11-25 123111

Contributing

Contributions are welcome! Please open an issue or submit a pull request.


About

"Serverless AWS backend for a multi-vendor app using Node.js, S3, Lambda, SNS, and Docker. Ensures scalable storage, event-driven communication, and consistent deployment. Empowers seamless integration and scalability, supporting diverse vendor functionalities. Cloud-native solutions for a robust multi-vendor application. Feel free to explore.. ❤️

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published