{"id":17156675,"url":"https://github.com/xiaonanln/go-consistent","last_synced_at":"2025-03-24T14:17:12.818Z","repository":{"id":57571544,"uuid":"145419802","full_name":"xiaonanln/go-consistent","owner":"xiaonanln","description":"Go consistent hashing library","archived":false,"fork":false,"pushed_at":"2021-03-16T04:23:49.000Z","size":10,"stargazers_count":2,"open_issues_count":1,"forks_count":0,"subscribers_count":3,"default_branch":"master","last_synced_at":"2025-01-29T19:12:34.459Z","etag":null,"topics":["consistent-hashing","consistent-hashing-library","murmur"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/xiaonanln.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-08-20T13:15:04.000Z","updated_at":"2019-09-10T18:11:31.000Z","dependencies_parsed_at":"2022-08-29T15:40:17.366Z","dependency_job_id":null,"html_url":"https://github.com/xiaonanln/go-consistent","commit_stats":null,"previous_names":[],"tags_count":1,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/xiaonanln%2Fgo-consistent","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/xiaonanln%2Fgo-consistent/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/xiaonanln%2Fgo-consistent/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/xiaonanln%2Fgo-consistent/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/xiaonanln","download_url":"https://codeload.github.com/xiaonanln/go-consistent/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":245284731,"owners_count":20590307,"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":["consistent-hashing","consistent-hashing-library","murmur"],"created_at":"2024-10-14T22:07:05.156Z","updated_at":"2025-03-24T14:17:12.791Z","avatar_url":"https://github.com/xiaonanln.png","language":"Go","readme":"# go-consistent\ngo consistent hashing library\n\n**It is NOT concurrency safe.**\n\n# Install \n```bash\ngo get github.com/xiaonanln/go-consistent\n```\n\n# Usage\n\n```go\nimport \"github.com/xiaonanln/go-consistent\"\n\n// Create Consistent Hashing\nc := consistent.New()\n// Hash returns ErrNoHost if there are no hosts\nc.Hash(\"key\") // returns \"\", consistent.ErrNoHost\n// Add adds a new hash\nc.Add(\"host1\")\nc.Hash(\"key\") // returns \"host1\", nil \n\nc.Add(\"host2\")\nc.Hash(\"key\") // returns \"host1\"/\"host2\", nil\n\n// SetReplica changes replica. The defualt replica is 20\nc.SetReplica(100) // reset replica from 20 to 100\n```\n# Time complexity\nAssuming `N` is number of hosts:  \n* `Add` = `O(N)`\n* `Hash` = `O(log N)`\n* `SetReplica` = `O(N)`\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fxiaonanln%2Fgo-consistent","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fxiaonanln%2Fgo-consistent","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fxiaonanln%2Fgo-consistent/lists"}