watch
观察领导者key
params := map[string]interface{}{}
params["type"] = "key"
params["key"] = "path/to/leader/key"
plan, err := watch.Parse(params)
if err != nil {
// 错误处理
}
// 当所监视的key发生任何更改时调用该handler函数
plan.Handler = handler
// 阻塞调用,因此这段代码应该在goroutine中运行
plan.RunWithClientAndHclog(client, nil)
handler函数
func handler(index uint64, result interface{}) {
log.Printf("watch data: %s", result)
// 检查返回的键是否有sessionID
// 如果session ID存在,则key被某个节点获取
// 如果没有,目前没有领导者,尝试获取key
}
使用watch功能,可以观察key的变化。如果领导者key发送变化,Consul会通知的,因此session会被删除/自动过期,领导者key释放被其他节点获取,导致KV的更新。所有watch这个key的节点都会被通知有变化。在收到通知后,所有节点可以检查key的状态,并运行新的选举。