微服务Consul系列之服务注册与服务发现

[复制链接]
278|3
手机看帖
扫描二维码
随时随地手机跟帖
keer_zu|  楼主 | 2020-10-19 14:43 | 显示全部楼层 |阅读模式
Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置。与其他分布式服务注册与发现的方案,Consul的方案更"一站式",内置了服务注册与发现框 架、分布一致性协议实现、健康检查、Key/Value存储、多数据中心方案,不再需要依赖其他工具(比如ZooKeeper等)。使用起来也较 为简单。Consul用Golang实现,因此具有天然可移植性(支持Linux、windows和Mac OS X);安装包仅包含一个可执行文件,方便部署,与Docker等轻量级容器可无缝配合。

Consul 的使用场景
  • docker 实例的注册与配置共享
  • coreos 实例的注册与配置共享
  • vitess 集群
  • SaaS 应用的配置共享
  • 与 confd 服务集成,动态生成 nginx 和 haproxy 配置文件
Consul 的优势
  • 使用 Raft 算法来保证一致性, 比复杂的 Paxos 算法更直接. 相比较而言, zookeeper 采用的是 Paxos, 而 etcd 使用的则是 Raft.
  • 支持多数据中心,内外网的服务采用不同的端口进行监听。 多数据中心集群可以避免单数据中心的单点故障,而其部署则需要考虑网络延迟, 分片等情况等. zookeeper 和 etcd 均不提供多数据中心功能的支持.
  • 支持健康检查. etcd 不提供此功能.
  • 支持 http 和 dns 协议接口. zookeeper 的集成较为复杂, etcd 只支持 http 协议.
  • 官方提供web管理界面, etcd 无此功能.
综合比较, Consul 作为服务注册和配置管理的新星, 比较值得关注和研究.
Consul 的角色
client: 客户端, 无状态, 将 HTTP 和 DNS 接口请求转发给局域网内的服务端集群. server: 服务端, 保存配置信息, 高可用集群, 在局域网内与本地客户端通讯, 通过广域网与其他数据中心通讯. 每个数据中心的 server 数量推荐为 3 个或是 5 个.


651465f8d359f7225a.png

.NET 客户端 https://github.com/PlayFab/consuldotnet/ ,Nuget https://www.nuget.org/packages/Consul/
具体**参考https://playfab.com/blog/2015/05/19/porting-consul-go-api-c
        Docker image with mono-complete and consul-agent: https://github.com/catwithboots/monoconsul
使用Apache Mesos和Consul实现服务的注册发现
使用Terraform与Consul自动化现代数据中心
使用consul实现分布式服务注册和发现
Consul环境搭建和测试
Docker 负载均衡与服务发现

使用特权

评论回复

相关帖子

keer_zu|  楼主 | 2020-10-19 15:32 | 显示全部楼层
28895f8d40efe303c.png

使用特权

评论回复
keer_zu|  楼主 | 2020-10-19 15:40 | 显示全部楼层

476305f8d42dbb076d.png



使用特权

评论回复
keer_zu|  楼主 | 2020-10-19 15:41 | 显示全部楼层
download:
https://www.consul.io/downloads.html

970085f8d432e5c506.png

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

个人签名:qq群:49734243 Email:zukeqiang@gmail.com

1304

主题

12233

帖子

53

粉丝