服务发现(Service Discovery)是指什么?
服务发现(Service Discovery) 概述 从 Internet 刚开始兴起,如何动态感知后端服务的地址变化就是一个必须要面对的问 题,为此人们定义了 DNS 协议,基于此协议,调用方只需要记住由固定字符串组成的域 名,就能轻松完成对后端服务的访问,而不用担心流量最终会访问到哪些机器 IP,因为有 代理组件会基于 DNS 地址解析后的地址列表,将流量透明的、均匀的分发到不同的后端 机器上。在使用微服务构建复杂的分布式系统时,如何感知 backend 服务实例的动态上下线, 也是微服务框架最需要关心并解决的问题之一。业界将这个问题称之为 - 微服务的地址发 现(Service Discovery),业界比较有代表性的微服务框架如 SpringCloud、 Microservices、Dubbo 等都抽象了强大的动态地址发现能力,并且为了满足微服务业务 场景的需求,绝大多数框架的地址发现都是基于自己设计的一套机制来实现,因此在能力、 灵活性上都要比传统 DNS 丰富得多。如 SpringCloud 中常用的 Eureka, Dubbo 中 常用的 Zookeeper、Nacos 等,这些注册中心实现不止能够传递地址(IP + Port), 还包括一些微服务的 Metadata 信息,如实例序列化类型、实例方法列表、各个方法级的 定制化配置等。
对于微服务架构来说,每个服务都可以单独地管理和部署。比如把服务部署在多个节点上,前端请求过来之后采用负载均衡策略把流量打到具体的机器上。如果某个节点宕机(比如最常见的原因Out of Memory),这时候用户的请求达到了宕机的机器上就会造成很不好的用户体验。又比如说横向扩展的时候,手动添加配置也很繁杂。
服务注册与发现就是用来解决这些问题的。所有服务的IP地址以及端口都存放在一个强一致性的数据中心。对于服务宕机以及添加能够自动发现,不再需要人工干预。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。