golang 链接 etcd 集群的疑惑。。。。。。。

2019-11-27 17:41:07 +08:00
 xmge
package main

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

func main() {
	cli, err := clientv3.New(clientv3.Config{
		Endpoints: []string{"localhost:2379", "localhost:2479", "localhost:2579"},
		DialTimeout: 5 * time.Second,
	})


	if err != nil {
		log.Fatal(err)
	}

	kv := clientv3.NewKV(cli)

	putResp, err := kv.Put(context.TODO(),"/test/key1", "Hello etcd!")
	fmt.Printf("PutResponse: %v, err: %v\n", putResp, err)
}

本机有三个 etcd 节点,分别为 2379,2479,2579。是以集群方式搭建的,在测试g olang 链接 etcd 集群时,有以下疑问:

1、杀死其中两个节点,只有有一个节点存活,go 代码就能跑通,它的实现原理是什么,原谅我找源码找了半天没找到。想问下他的运行机制是怎样的?

2、golang 链接 etcd 集群的方式就是这样吗?就是链接多个,只要有一个存活就不影响程序运行,这是 etcd 集群正确的使用方式吗?

感谢大佬,好人一生平安。

2505 次点击
所在节点    程序员
7 条回复
gy0624ww
2019-11-27 17:48:19 +08:00
一个节点当然能跑通了,etcd 是分布式存储,你一个节点就是单机模式了呗
etcd 多个节点会有选举,选出个 leader 和客户端交互。
你说的就一个存活了,那肯定那个存活的就是 leader 了。
xkeyideal
2019-11-27 17:53:47 +08:00
给你简单解释一下:
1. etcd 的通信是基于 grpc 的,grpc 每次非 stream 的请求,每次使用的 server 地址都可能不一样,详细看可以看 clientv3 的 balance 源码,看看 etcd 怎么做 grpc 连接的负载均衡的,记着是每次请求
2. etcd 是基于 raft 协议的,写请求会自动转到主,读请求(不包括非线性读)可以读从,线性读的机制比较复杂,你可以认为是主节点响应的(这里比较复杂,建议看源码)
3. raft 集群,如果主挂掉,那么其他机器会自动选主,所以你说的一台机器挂掉是不影响 etcd 的使用的,当挂掉的机器恢复后,会变成从机,然后从主机同步数据
4. etcd golang clientv3 连接 etcd servers 的代码相对来说比较简单,很容易看懂,但想要完整的理解全套逻辑,需要看 server 的部分代码,raft 部分基本上不需要看,只需要理解 raft 协议本身即可
xkeyideal
2019-11-27 17:57:38 +08:00
5. clientv3 里面有定时从 etcd 集群更新当前 etcd 集群可提供服务机器的代码 https://github.com/etcd-io/etcd/blob/master/clientv3/client.go#L193, 所以并不是你说的只要有一个存活就不影响程序运行,那么说明你的测试密度不够,客户端肯定不是实时响应服务端机器变化的
jejer
2019-11-28 09:29:56 +08:00
client 同时尝试 3 个 endpoint
xmge
2019-11-28 09:49:36 +08:00
@xkeyideal 感谢大佬解释,我会再仔细看看这个实现是怎样的,会把发下你的写在下面。。
xmge
2019-11-28 09:50:39 +08:00
@gy0624ww 和二楼的解释有点冲突,我仔细看看源码或者文章啥的,会把发现的写在下面
xmge
2019-11-28 09:51:09 +08:00
@jejer 哈哈,我也是这样感觉的,找了半天,没发现它在哪里尝试链接。。。。。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/623700

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX