ZBLOG

golang etcd 服务发现

在分布式系统中,服务发现是一个重要的组件。etcd可以用作服务注册和发现的基础设施,而Golang中也有相应的库可以实现对etcd的服务发现。

以下是一种基于go-etcd/etcd包的简单示例:

  1. 服务注册
import (
    "context"
    "github.com/coreos/etcd/clientv3"
)

// 创建etcd客户端
cli, err := clientv3.New(clientv3.Config{
        Endpoints:   []string{"localhost:2379"}, // etcd服务器地址
        DialTimeout: 5 * time.Second,
})
if err != nil {
    log.Fatal(err)
}

defer cli.Close() // 关闭连接

// 注册服务,key为“service/name”,value为IP和端口号
lease := clientv3.NewLease(cli)
grantResp, _ := lease.Grant(context.Background(), 10) // 设置租约时间为10秒
_, err = cli.Put(context.Background(), "service/name", "127.0.0.1:8080", clientv3.WithLease(grantResp.ID))
if err != nil {
    log.Fatal(err)
}
  1. 服务发现
import (
    "context"
    "fmt"
    "github.com/coreos/etcd/clientv3"
)

// 创建etcd客户端
cli, err := clientv3.New(clientv3.Config{
        Endpoints:   []string{"localhost:2379"}, // etcd服务器地址
        DialTimeout: 5 * time.Second,
})
if err != nil {
    log.Fatal(err)
}

defer cli.Close() // 关闭连接

// 获取服务列表,前缀为“service/”
resp, err := cli.Get(context.Background(), "service/", clientv3.WithPrefix())
if err != nil {
    log.Fatal(err)
}

for _, ev := range resp.Kvs {
    fmt.Printf("%s : %s\n", ev.Key, ev.Value)
}

以上示例演示了如何使用etcd实现服务注册和发现,可以根据实际需求进行更进一步的封装和扩展。

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=6720

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?