golang的etcd

栏目: Go · 发布时间: 5年前

内容简介:etcd 是由etcd 有golang 编写 kubernets体系中主要用于 服务注册 + 服务发现.// 以下为俺们封装的grpc调用 etcd的调用逻辑.

etcd 是由 CoreOS 开发,用于可靠地存储集群的配置数据的一种持久性,轻量型的,分布式的键-值数据存储。表示在任何给定时间点处的集群的整体状态。其他组件在注意到存储的变化之后,会变成相应的状态。

etcd 有golang 编写 kubernets体系中主要用于 服务注册 + 服务发现.

// 以下为俺们封装的grpc调用 etcd的调用逻辑.

  1. 服务端. 注册服务.
  2. client端. 发现服务. 使用服务.

2.1 导入 invoker 包

main.go -> service.Init() -> 相关grpc的初始化. -> 导入 git.dz11.com/vega/invoker 包.

2.2 invoker包的init函数执行. 在 invoker/register.go 中.

init() 参数处理 -> 配置文件处理 -> invokerHandler = initInvoker() -> 各种服务 grpc的话 Conf.initHrpc(invokerHandler)

2.3 Conf.initHrpc

新建 GRPCResolver -> grpc.RoundRobin -> grpc.DialContext -> 返回得到的grpc的conn

2.4 grpc.DialContext

一系列处理之后, cc.resolverWrapper, err = newCCResolverWrapper(cc) -> rb.Build -> (*passthroughBuilder) Build ->

r.start() -> r.cc.NewAddress() ->


以上所述就是小编给大家介绍的《golang的etcd》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

深度学习

深度学习

[美]特伦斯·谢诺夫斯基(Terrence Sejnowski) / 姜悦兵 / 中信出版集团 / 2019-2 / 88

全球科技巨头纷纷拥抱深度学习,自动驾驶、AI医疗、语音识别、图像识别、智能翻译以及震惊世界的AlphaGo,背后都是深度学习在发挥神奇的作用。深度学习是人工智能从概念到繁荣得以实现的主流技术。经过深度学习训练的计算机,不再被动按照指令运转,而是像自然进化的生命那样,开始自主地从经验中学习。 本书作者特伦斯·谢诺夫斯基是全球人工智能十大科学家之一、深度学习先驱及奠基者,亲历了深度学习在20世纪......一起来看看 《深度学习》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

MD5 加密
MD5 加密

MD5 加密工具