Skip to content

Architecture for a rate limited fault tolerant server in GoLang

Notifications You must be signed in to change notification settings

anurag1004/RLFT-Arch-Simulator

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

RLFT-Arch-Simulator

Description

RLFT-Arch-Simulator is a simulation of an architecture for a rate-limited fault-tolerant server implemented in GoLang. Please note that this project does not represent a real server, nor does it send or process requests like an actual server. Instead, it provides a simulated environment for exploring and understanding the architectural concepts involved in building a rate-limited fault-tolerant server.

Table of Contents

The RLFT-Arch-Simulator project aims to demonstrate the principles of building a rate-limited fault-tolerant server using GoLang. While it does not function as a production server, it serves as a valuable educational tool for those interested in understanding the underlying architecture of such systems.

Architecture Diagram

Architecture Diagram Description: A visual representation of the RLFT architecture.

Architecture Explanation

Components

The cluster's job is to create, spawn and monitor nodes health.

Handle requests and sends response back to client (max k reqs at the time i.e each node is rate-limited)

  • sendRequest routine - sends requests to a single channel (unbuffered)
  • responseGrabber routine - receives response from nodes
  • Simulation of rate-limited fault-tolerant server architecture.
  • Written in GoLang, making it easy to explore the codebase.
  • Educational resource for learning about server architecture concepts.

To get started with RLFT-Arch-Simulator, you can follow these steps:

  1. Clone the repository to your local machine:

    git clone https://github.com/anurag0608/RLFT-Arch-Simulator.git

  2. cd RLFT-Arch-Simulator

  3. go run .

This project primarily serves an educational purpose. You can explore the code files to gain insights into the architecture of a rate-limited fault-tolerant server. Feel free to modify and experiment with the code to better understand the concepts involved.

Contributions to RLFT-Arch-Simulator are welcome! If you'd like to contribute to the project, please follow these steps:

  1. Fork the repository.
  2. Create a new branch for your feature or bug fix: git checkout -b feature/your-feature-name
  3. Make your changes and commit them: git commit -m "Add your commit message here"
  4. Push your changes to your fork: git push origin feature/your-feature-name
  5. Open a pull request on the original repository.

I encourage contributions that improve the clarity and educational value of the project.

This project is licensed under the MIT License. Feel free to use, modify, and distribute it as per the terms of the license.

About

Architecture for a rate limited fault tolerant server in GoLang

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages