golang etcdclientv3使用说明

clientv3.New() 创建连接

config = ec.Config{
  Endpoints:   []string{"10.0.0.5:2379"},  //连接的etcd集群地址,这里为单机的故一个地址
  DialTimeout: 30 * time.Second,   //超时时长
}

 

返回值为clientv3.Client结构体

golang etcdclientv3使用说明_第1张图片

KV是经常使用的类型,主要用来操作key value值

client.Put() 实际上就是KV接口实现的一个方法

golang etcdclientv3使用说明_第2张图片

 

KV.Put 向etcd中插入一个Key,如存在则替换新的值。

if putRes, err = kv.Put(context.TODO(), "/cron/jobs/job3", "test111111 hel3123lo",ec.WithPrevKV()); err != nil {
	fmt.Println(err)
} else {
	fmt.Println("revision: ", putRes.Header.Revision)
	if putRes.PrevKv != nil{
		fmt.Println(string(putRes.PrevKv.Value))
	}
}

 

WithPrevKV()获取Put事件操作之前的键值对

golang etcdclientv3使用说明_第3张图片

package main

import (
	"context"
	"fmt"
	"time"

	ec "go.etcd.io/etcd/clientv3"
)

func main() {
	var (
		config ec.Config
		client *ec.Client
		err    error
		kv     ec.KV
		putRes *ec.PutResponse
	)

	config = ec.Config{
		Endpoints:   []string{"10.0.0.5:2379"},
		DialTimeout: 30 * time.Second,
	}

	if client, err = ec.New(config); err != nil {
		fmt.Println(err)
		return
	}

	kv = ec.NewKV(client)

	if putRes, err = kv.Put(context.TODO(), "/cron/jobs/job3", "test111111 hel3123lo",ec.WithPrevKV()); err != nil {
		fmt.Println(err)
	} else {
		fmt.Println("revision: ", putRes.Header.Revision)
		if putRes.PrevKv != nil{
			fmt.Println(string(putRes.PrevKv.Value))
		}
	}

	op:= ec.OpGet("/cron/jobs/job3")
	fmt.Println(string(op.KeyBytes()))
}

golang etcdclientv3使用说明_第4张图片

 

 如果Key不存在,则没有事件操作之前的信息

golang etcdclientv3使用说明_第5张图片

[root@node01 ~]# ETCDCTL_API=3 etcdctl get /cron/jobs/ --prefix
/cron/jobs/job1
test hello
/cron/jobs/job2
test111111 hel3123lo
/cron/jobs/job3
test22222 hello2222
/cron/jobs/job4
test22222 hello2222

获取key的值

package main

import (
	"context"
	"fmt"
	ec "go.etcd.io/etcd/clientv3"
	"time"
)

var(
	conf ec.Config
	cli *ec.Client
	err error
	kv ec.KV
	getResp *ec.GetResponse
)

func main(){
	conf = ec.Config{
		Endpoints:[]string{"10.0.0.5:2379"},
		DialTimeout:time.Second*30,
	}

	if cli,err = ec.New(conf); err != nil{
		fmt.Println(err)
	}
	kv = ec.NewKV(cli)

	getResp,err = kv.Get(context.TODO(),"/cron/jobs/job3")

	fmt.Println(getResp.Kvs)
}

 

运行结果

[key:"/cron/jobs/job3" create_revision:11 mod_revision:14 version:4 value:"test22222 hello2222" ]

Process finished with exit code 0

create_revision: 为创建时的版本

mod_revision:修改版本

version:自从创建以来修改的次数。 值会不断的递增。

 

 

删除key

delResp, err = kv.Delete(context.TODO(), "/cron/jobs/job4", ec.WithPrevKV());

if len(delResp.PrevKvs) != 0 {
  fmt.Println(delResp)
}

 

删除前的多个key

  

一次性删除多个key

kv.Delete(context.TODO(), "/cron/jobs/", ec.WithPrefix())

 
WithPrefix():以这个key为前缀的key都删除掉

 

转载于:https://www.cnblogs.com/LC161616/p/10380601.html

你可能感兴趣的:(golang etcdclientv3使用说明)