golang consul 观察者watch

watch

使用consul实现领导者选举

观察领导者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的状态,并运行新的选举。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值