{"id":19016039,"url":"https://github.com/varunu28/graft","last_synced_at":"2025-04-23T01:58:05.849Z","repository":{"id":113372154,"uuid":"461539746","full_name":"varunu28/graft","owner":"varunu28","description":"🪵 From scratch implementation of Raft consensus algorithm in Go","archived":false,"fork":false,"pushed_at":"2022-03-21T09:08:34.000Z","size":15783,"stargazers_count":39,"open_issues_count":0,"forks_count":10,"subscribers_count":2,"default_branch":"main","last_synced_at":"2025-04-23T01:57:58.948Z","etag":null,"topics":["consensus","distributed-computing","distributed-systems","golang","raft"],"latest_commit_sha":null,"homepage":"https://distributed-computing-musings.com/2022/03/implementing-raft-consensus-algorithm-in-go/","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/varunu28.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,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2022-02-20T16:04:57.000Z","updated_at":"2025-04-16T01:51:15.000Z","dependencies_parsed_at":"2023-06-15T11:30:57.446Z","dependency_job_id":null,"html_url":"https://github.com/varunu28/graft","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/varunu28%2Fgraft","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/varunu28%2Fgraft/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/varunu28%2Fgraft/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/varunu28%2Fgraft/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/varunu28","download_url":"https://codeload.github.com/varunu28/graft/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":250354302,"owners_count":21416751,"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":["consensus","distributed-computing","distributed-systems","golang","raft"],"created_at":"2024-11-08T19:40:40.602Z","updated_at":"2025-04-23T01:58:05.844Z","avatar_url":"https://github.com/varunu28.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"# GRaft\nFrom scratch implementation of [Raft consensus algorithm](https://raft.github.io/raft.pdf) in Go. \n\n[Blog post describing an overview of Raft](https://distributed-computing-musings.com/2022/03/implementing-raft-consensus-algorithm-in-go/)\n\n## Raft in action\n\n#### Leader syncing up with follower nodes\n![Leader sync-up](https://github.com/varunu28/go-raft/blob/main/demo-gifs/Leader%20syncup.gif)\n\n#### Leader election\n![Leader Election Start](https://github.com/varunu28/go-raft/blob/main/demo-gifs/Leader%20Election%20Start.gif)\n\n#### Client-Server E2E Raft Demo\n![Client-Server E2E](https://github.com/varunu28/go-raft/blob/main/demo-gifs/Client%20Server%20E2E.gif)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvarunu28%2Fgraft","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fvarunu28%2Fgraft","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvarunu28%2Fgraft/lists"}