返回介绍

微服务中的服务发现

发布于 2019-09-08 09:20:52 字数 1385 浏览 1101 评论 0 收藏 0

在单体架构时,因为服务不会经常和动态迁移,所有服务地址可以直接在配置文件中配置,所以也不会有服务发现的问题。但是对于微服务来说,应用的拆分,服务之间的解耦,和服务动态扩展带来的服务迁移,服务发现就成了微服务中的一个关键问题。

服务发现分为客户端服务发现服务端服务发现两种,架构如下图所示。

微服务中的服务发现

这两种架构都各有利弊,我们拿客户端服务发现软件Eureka和服务端服务发现架构Kubernetes/SkyDNS+Ingress LB+Traefik+PowerDNS为例说明。

服务发现方案ProsCons
Eureka使用简单,适用于java语言开发的项目,比服务端服务发现少一次网络跳转对非Java语言的支持不够好,Consumer需要内置特定的服务发现客户端和发现逻辑
KubernetesConsumer无需关注服务发现具体细节,只需知道服务的DNS域名即可,支持异构语言开发需要基础设施支撑,多了一次网络跳转,可能有性能损失

Eureka 也不是单独使用的,一般会配合 ribbon 一起使用,ribbon 作为路由和负载均衡。

Ribbon提供一组丰富的功能集:

  • 多种内建的负载均衡规则:
    • Round-robin 轮询负载均衡
    • 平均加权响应时间负载均衡
    • 随机负载均衡
    • 可用性过滤负载均衡(避免跳闸线路和高并发链接数)
    • 自定义负载均衡插件系统
  • 与服务发现解决方案的可拔插集成(包括Eureka)
  • 云原生智能,例如可用区亲和性和不健康区规避
  • 内建的故障恢复能力

参考

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文