etcd支持通过watch API来监听key的变化,当一个key被删除时也会触发相应的事件。具体实现可以参考以下代码示例:
// 创建etcd客户端连接
cli, err := clientv3.New(clientv3.Config{
Endpoints: []string{"localhost:2379"},
})
if err != nil {
log.Fatal(err)
}
defer cli.Close()
// key的变化监听函数
watcher := cli.Watch(context.Background(), "mykey", clientv3.WithPrefix())
for {
select {
case resp := <-watcher:
for _, ev := range resp.Events {
if ev.Type == mvccpb.DELETE {
fmt.Println("key has been deleted:", string(ev.Kv.Key))
}
}
}
}
上述代码中,我们首先创建了etcd客户端连接,然后使用Watch函数创建了一个watcher,来监听以”mykey”为前缀的所有key的变化。当有任何一个key被删除时,就会触发相应的DELETE事件,从而在watcher所在的select语句中得到通知,进而执行对应的操作。