Git Product home page Git Product logo

rache's Introduction

rache

Rache is a distributed key-value in-memory cache based on Raft consensus algorithm in Golang and gRPC provided gRPC provides the underlying RPC communication service between various servers.

Rache supports concurrent secure access by multiple clients, and achieves data consistency among various servers according to the raft protocol. Raft is a consensus algorithm that is designed to be easy to understand. It's equivalent to Paxos in fault-tolerance and performance. If you want to learn more about the principles of the raft algorithm, I think this website (https://raft.github.io/) can definitely help you and the best way is to read the raft paper.

In a distributed raft cluster, the servers communicate through remote procedure calls. I chose gRPC as the underlying RPC communication framework. It is based on Google's protocol buffer, has high performance, and supports streaming RPC communication. Details Information can be found here: https://grpc.io/docs/reference/.

If you want to learn the raft algorithm, or build a simple distributed application for yourself, I believe that it will be very helpful to read this project. There are detailed comments in the code. I will keep updating this project and keep improving it, hoping that the performance and functions will become more and more powerful!

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.