Slide 30
Slide 30 text
# ϋογϡؔ32bit unsigned intͷϋογϡΛฦ͢
# CRC32, MD5ͷ্Ґ32bitͳͲͰ࣮
func hash(key string) uint32 { ... }
# ϊʔυͷϋογϡΛܭࢉ
for _, node := range nodes {
# ͻͱͭͷϊʔυຖʹ160ݸͷϋογϡΛܭࢉ
for i := 0; i < 160; i++ {
k := fmt.Sprintf(“%s-%d”, node, i)
# ϊʔυ໊ͱϋογϡͷϖΞΛՃ
continuum.add(node, hash(k))
}
}
# ϋογϡͰιʔτ͓ͯ͘͠
sort.Sort(continuum)
ֿאӦـӡӶӜӯҐܭࢉ