golang 链接 etcd 集群的疑惑。。。。。。。 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
xmge
V2EX    程序员

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

  •  
  •   xmge 2019-11-27 17:41:07 +08:00 2822 次点击
    这是一个创建于 2144 天前的主题,其中的信息可能已经有所发展或是发生改变。
    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 集群正确的使用方式吗?

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

    7 条回复    2019-11-28 09:51:09 +08:00
    gy0624ww
        1
    gy0624ww  
       2019-11-27 17:48:19 +08:00
    一个节点当然能跑通了,etcd 是分布式存储,你一个节点就是单机模式了呗
    etcd 多个节点会有选举,选出个 leader 和客户端交互。
    你说的就一个存活了,那肯定那个存活的就是 leader 了。
    xkeyideal
        2
    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
        3
    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
        4
    jejer  
       2019-11-28 09:29:56 +08:00
    client 同时尝试 3 个 endpoint
    xmge
        5
    xmge  
    OP
       2019-11-28 09:49:36 +08:00
    @xkeyideal 感谢大佬解释,我会再仔细看看这个实现是怎样的,会把发下你的写在下面。。
    xmge
        6
    xmge  
    OP
       2019-11-28 09:50:39 +08:00
    @gy0624ww 和二楼的解释有点冲突,我仔细看看源码或者文章啥的,会把发现的写在下面
    xmge
        7
    xmge  
    OP
       2019-11-28 09:51:09 +08:00
    @jejer 哈哈,我也是这样感觉的,找了半天,没发现它在哪里尝试链接。。。。。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2974 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 23ms UTC 12:11 PVG 20:11 LAX 05:11 JFK 08:11
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86