{"id":20321356,"url":"https://github.com/openacid/mmp3","last_synced_at":"2025-04-11T19:10:28.939Z","repository":{"id":43088798,"uuid":"419221726","full_name":"openacid/mmp3","owner":"openacid","description":"multi-master-paxos with 3 nodes","archived":false,"fork":false,"pushed_at":"2022-04-11T15:44:51.000Z","size":2619,"stargazers_count":13,"open_issues_count":0,"forks_count":2,"subscribers_count":5,"default_branch":"main","last_synced_at":"2025-03-25T15:03:56.420Z","etag":null,"topics":["multi-master","paxos"],"latest_commit_sha":null,"homepage":"https://blog.openacid.com/algo/mmp3","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/openacid.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2021-10-20T07:08:04.000Z","updated_at":"2024-09-04T08:18:30.000Z","dependencies_parsed_at":"2022-08-30T21:11:33.046Z","dependency_job_id":null,"html_url":"https://github.com/openacid/mmp3","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/openacid%2Fmmp3","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/openacid%2Fmmp3/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/openacid%2Fmmp3/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/openacid%2Fmmp3/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/openacid","download_url":"https://codeload.github.com/openacid/mmp3/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":248465344,"owners_count":21108244,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["multi-master","paxos"],"created_at":"2024-11-14T19:14:26.317Z","updated_at":"2025-04-11T19:10:28.907Z","avatar_url":"https://github.com/openacid.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"# mmp3: multi-master Paxos based kv storage\n\n![main](https://github.com/openacid/mmp3/workflows/test/badge.svg?branch=main)\n[![travis](https://travis-ci.com/openacid/mmp3.svg?branch=naive)](https://travis-ci.com/openacid/mmp3)\n\n![](https://blog.openacid.com/post-res/mmp3/digraphqueue_demosize=1010dpi=10-b5ab13197d2fba30.jpg)\n\nmmp3 中文介绍: https://blog.openacid.com/algo/mmp3\n\nMMP3 is a multi-master distributed consensus protocol built on top of classic Paxos.\nThe application API is similar to raft except that **every node is a leader** and can handle write requests. \n\n- Exhibits a distributed **log-state-machine** model, similar to raft.\n- Exactly three nodes in a cluster.\n- Every node is a leader and is able to handle write requests without conflict.\n- A message is committed in **exactly one RTT**(unlike epaxos which requires two RTT if logs interfere with others).\n\n# Question\n\nAny questions or suggestions, feel free to open a [issue][] :DDD.\n\n\n[issue]:                          https://github.com/openacid/mmp3/issues/new/choose\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fopenacid%2Fmmp3","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fopenacid%2Fmmp3","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fopenacid%2Fmmp3/lists"}