Golang的Etcd客户端

Etcd和Consul都是非常出名的服务化治理工具。本篇先来讲一下Etcd的使用。

学会使用

安装

go get github.com/coreos/etcd/client

引用

"github.com/coreos/etcd/client"

Example

cfg := client.Config{
    Endpoints:               []string{"http://127.0.0.1:2379"},
    Transport:               client.DefaultTransport,
    // set timeout per request to fail fast when the target endpoint is unavailable
    HeaderTimeoutPerRequest: time.Second,
}
c, err := client.New(cfg)
if err != nil {
    log.Fatal(err)
}

使用说明

创建客户端

c, err := client.New(cfg)
if err != nil {
    log.Fatal(err)
}

设置配置

kapi := client.NewKeysAPI(c)
log.Print("Setting '/foo' key with 'bar' value")
resp, err := kapi.Set(context.Background(), "/foo", "bar", nil)
if err != nil {
    log.Fatal(err)
} else {
    log.Printf("Set is done. Metadata is %q\n", resp)
}

读取配置

kapi := client.NewKeysAPI(c)
resp, err = kapi.Get(context.Background(), "/foo", nil)
if err != nil {
    log.Fatal(err)
} else {
    log.Printf("Get is done. Metadata is %q\n", resp)
    log.Printf("%q key has %q value\n", resp.Node.Key, resp.Node.Value)
}

订阅配置变更

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,991评论 19 139
  • from http://www.infoq.com/cn/articles/etcd-interpretation...
    小树苗苗阅读 13,998评论 3 38
  • 在互联网应用领域,服务的动态性需求十分常见,这就对服务的自动发现和可动态扩展提出了很高的要求。 微服务系统动辄上万...
    Liberalman阅读 8,118评论 23 80
  • 偶尔去回忆 回忆那些不属于我的青春 比如 好久不见的人 想送却没有送出的巧克力 放在盒里 不如去品味 每一颗都有她...
    晓玖的碎碎念阅读 157评论 0 0
  • 为期一个月的写作班,终于毕业了。我发现在总是喊着忙忙忙的日子里,也能挤出时间做一件每天都能坚持的事。 这...
    山风岚希阅读 407评论 0 0