You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
32 lines
546 B
32 lines
546 B
package broker
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
)
|
|
|
|
func TestPickMember(t *testing.T) {
|
|
|
|
servers := []string{
|
|
"s1:port",
|
|
"s2:port",
|
|
"s3:port",
|
|
"s5:port",
|
|
"s4:port",
|
|
}
|
|
|
|
total := 1000
|
|
|
|
distribution := make(map[string]int)
|
|
for i := 0; i < total; i++ {
|
|
tp := fmt.Sprintf("tp:%2d", i)
|
|
m := PickMember(servers, []byte(tp))
|
|
// println(tp, "=>", m)
|
|
distribution[m]++
|
|
}
|
|
|
|
for member, count := range distribution {
|
|
fmt.Printf("member: %s, key count: %d load=%.2f\n", member, count, float64(count*100)/float64(total/len(servers)))
|
|
}
|
|
|
|
}
|