forked from TrueCloudLab/hrw
Move repo to NSPCC (#1)
This commit is contained in:
parent
098fd24704
commit
29dac15c96
3 changed files with 22 additions and 8 deletions
2
LICENSE
2
LICENSE
|
@ -1,6 +1,6 @@
|
|||
MIT License
|
||||
|
||||
Copyright (c) 2019 Evgeniy Kulikov
|
||||
Copyright (c) 2019 NSPCC
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
|
|
26
README.md
26
README.md
|
@ -1,15 +1,29 @@
|
|||
# Golang HRW implementation
|
||||
|
||||
[data:image/s3,"s3://crabby-images/2758e/2758eac7d1fc127577cbe48118385d91d3a30fe2" alt="Build Status"](https://travis-ci.org/im-kulikov/hrw)
|
||||
[data:image/s3,"s3://crabby-images/97180/971806289601e5c6a41f2ae7d1d663297d7bc515" alt="codecov"](https://codecov.io/gh/im-kulikov/hrw)
|
||||
[data:image/s3,"s3://crabby-images/7f7e7/7f7e742b180d96d4413dcb16c9d330adc34050e6" alt="Report"](https://goreportcard.com/report/github.com/im-kulikov/hrw)
|
||||
[data:image/s3,"s3://crabby-images/4c99c/4c99c35749276f6684a680a67e9286f93175c9a5" alt="GitHub release"](https://github.com/im-kulikov/hrw)
|
||||
[data:image/s3,"s3://crabby-images/53a08/53a08167796de3df0352f6b80147eb98f6830004" alt="Build Status"](https://travis-ci.org/nspcc-dev/hrw)
|
||||
[data:image/s3,"s3://crabby-images/c559f/c559f1d48f937e567c01406fa4119dd5769cd597" alt="codecov"](https://codecov.io/gh/nspcc-dev/hrw)
|
||||
[data:image/s3,"s3://crabby-images/ddf6e/ddf6e61e32f9e5151a21136b83a5b2adb15cae82" alt="Report"](https://goreportcard.com/report/github.com/nspcc-dev/hrw)
|
||||
[data:image/s3,"s3://crabby-images/8ddb3/8ddb315fe89787cefcc5b785074a9225dc7ce97f" alt="GitHub release"](https://github.com/nspcc-dev/hrw)
|
||||
|
||||
[Rendezvous or highest random weight](https://en.wikipedia.org/wiki/Rendezvous_hashing) (HRW) hashing is an algorithm that allows clients to achieve distributed agreement on a set of k options out of a possible set of n options. A typical application is when clients need to agree on which sites (or proxies) objects are assigned to. When k is 1, it subsumes the goals of consistent hashing, using an entirely different method.
|
||||
|
||||
## Install
|
||||
|
||||
`go get github.com/im-kulikov/hrw`
|
||||
`go get github.com/nspcc-dev/hrw`
|
||||
|
||||
## Benchmark:
|
||||
|
||||
```
|
||||
BenchmarkSortByWeight_fnv_10-8 3000000 435 ns/op 224 B/op 3 allocs/op
|
||||
BenchmarkSortByWeight_fnv_100-8 200000 7238 ns/op 1856 B/op 3 allocs/op
|
||||
BenchmarkSortByWeight_fnv_1000-8 10000 163158 ns/op 16448 B/op 3 allocs/op
|
||||
BenchmarkSortByIndex_fnv_10-8 2000000 642 ns/op 384 B/op 7 allocs/op
|
||||
BenchmarkSortByIndex_fnv_100-8 200000 8045 ns/op 2928 B/op 7 allocs/op
|
||||
BenchmarkSortByIndex_fnv_1000-8 10000 227527 ns/op 25728 B/op 7 allocs/op
|
||||
BenchmarkSortByValue_fnv_10-8 1000000 1244 ns/op 544 B/op 17 allocs/op
|
||||
BenchmarkSortByValue_fnv_100-8 100000 12397 ns/op 4528 B/op 107 allocs/op
|
||||
BenchmarkSortByValue_fnv_1000-8 10000 154278 ns/op 41728 B/op 1007 allocs/op
|
||||
```
|
||||
|
||||
## Example
|
||||
|
||||
|
@ -19,7 +33,7 @@ package main
|
|||
import (
|
||||
"fmt"
|
||||
|
||||
"github.com/im-kulikov/hrw"
|
||||
"github.com/nspcc-dev/hrw"
|
||||
)
|
||||
|
||||
func main() {
|
||||
|
|
2
go.mod
2
go.mod
|
@ -1,3 +1,3 @@
|
|||
module github.com/im-kulikov/hrw
|
||||
module github.com/nspcc-dev/hrw
|
||||
|
||||
require github.com/spaolacci/murmur3 v0.0.0-20180118202830-f09979ecbc72
|
||||
|
|
Loading…
Add table
Reference in a new issue