在分布式系统中,服务发现是一个重要的组件。etcd可以用作服务注册和发现的基础设施,而Golang中也有相应的库可以实现对etcd的服务发现。
以下是一种基于go-etcd/etcd包的简单示例:
- 服务注册
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)
}
- 服务发现
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实现服务注册和发现,可以根据实际需求进行更进一步的封装和扩展。




