Gossip 协定
一种共识算法,具体的原理倡议给位小伙伴自行谷歌
Gossip 协定包引入
$ go get github.com/hashicorp/[email protected]
测试
// gossip.gopackage mainimport( "fmt" "github.com/hashicorp/memberlist")func main(){ // 应用 Create 办法创立一个成员实例, 这个成员实例就代表着一群的机器 list, err := memberlist.Create(memberlist.DefaultLocalConfig()) if err != nil{ panic(err) } // 应用 Join 办法退出一个曾经存在的机器群 // 这里的参数是一个 string 切片,只有填写这个集群中的一台机器即可, // gossip 协定会将这个“谰言”散播给机器群的所有机器 _, err = list.Join([]string{"0.0.0.0"}) if err != nil{ panic(err) } for _, node := range list.Members(){ fmt.Println(node.Name, node.Addr) }}
$ go run gossip.go2022/10/20 00:28:52 [DEBUG] memberlist: Initiating push/pull sync with: 127.0.0.1:79462022/10/20 00:28:52 [DEBUG] memberlist: Stream connection from=127.0.0.1:32970634abb028f5466864d91f4a1 192.168.42.6