亚马逊AWS官方博客

Amazon ECS 服务发现全新启用方法

微服务与服务发现

微服务是一种软件开发的组织和架构方法,它可以加快软件交付周期、增强创新和自主性,提高软件的可维护性和可伸缩、可扩展性,同时也提高了企业开发和发布软件服务的能力。使用微服务架构,软件产品将由多个独立的、可通过 API 进行 交互的服务组成。这些服务将由各个小团队独自负责。 同时微服务之间的调用组成了一个复杂依赖关系图表。现代架构的一个最佳实践是允许服务制定自己的依赖关系来松耦合的组合这些服务,但是这在动态变化的容器环境里会变得复杂起来,因为你需要找到目标服务的连接地址。

如何让服务发现彼此并进行交互,这是微服务架构必须解决的问题。服务发现包括 检查服务的健康状态以及自动发现新服务上线。传统的服务发现方法,如 consul, etcd 或 zoo keeper,都很好地解决了这个问题,但它们需要预配置和维护额外的基础设施或在您的容器或您的实例上安装代理。 之前,为确保服务能够发现并相互连接,您必须配置和运行自己的服务发现系统或将每个服务连接到负载均衡器。 现在,您可以在 ECS 控制台、AWS CLI 或使用 ECS API 中为您的容器化服务启用服务发现。

Amazon Route 53 服务注册和自动命名 API

Amazon ECS 使用 Route 53 自动命名 API 来创建和管理服务名称注册表。名称会自动映射到一组 DNS 记录,这样您可以使用别名来引用服务,并将此别名自动解析到服务在运行时的终端节点。您可以在服务的任务定义中指定运行状况检查条件,Amazon ECS 将确保仅通过服务查找返回运行正常的服务终端节点。

使用 Amazon ECS 的服务发现功能时,您将按照所使用的 Route 53 资源量以及您的服务所执行的查找查询量付费,包括您创建的每个命名空间。服务运行状况检查不发生额外的费用。有关定价的更多信息,请参阅文档。 现在,使用 AWS Fargate 或 EC2 启动类型及 awsvpc 联网模式的 Amazon ECS 任务均可使用服务发现功能。

您可以在所有提供 Amazon ECS 和 Amazon Route 53 自动命名服务的 AWS 区域使用 Amazon ECS 服务发现功能,包括美国东部 (弗吉尼亚北部)、美国东部 (俄亥俄)、美国西部 (俄勒冈) 和欧洲 (爱尔兰) 区域。有关 AWS 区域和服务的更多信息,请查看 AWS 全球区域表

Amazon ECS服务发现创建和使用

服务发现组件

服务发现命名空间:共享相同域名的服务的逻辑组,例如 example.com。每个 Route 53 托管区域和每个 VPC 需要一个命名空间。如果您从 Amazon ECS 控制台使用服务发现,则工作流为每个 ECS 集群创建一个私有命名空间。

服务发现服务:存在于服务发现命名空间中,由命名空间的服务名称和 DNS 配置组成。它提供了以下核心组件:

  • 服务目录:让您可通过 DNS 或 Route 53 自动命名 API 查找服务,并获取一个或多个可用于连接到该服务的可用终端节点。

运行状况检查:执行定期容器级别的运行状况检查。如果终端节点不传递运行状况检查,则会将其从 DNS 路由中删除并标记为不正常。

具体操作DEMO演示

流程是这样的:在ECS创建任务定义模版,使用模版来创建服务,创建服务的过程中会进行服务发现的配置,会调用Route53的API来创建一个命名空间,和对应服务的Endpoint,以及将运行的任务对应的内部IP注册,最后可以在ECS的服务详细信息界面和Route53的Record Sets中查看到结果,消费者调用时直接对Endpoint请求,会到任务的内部IP。

这个DEMO是在美东1区来操作的。

1.在ECS界面创建任务定义模版

* 注意目前服务发现只支持 awsvpc 模式,连接什么是 awsvpc 请查看这个链接

2. 创建服务

3. 下一步,填写网络,安全相关设置后,在服务发现部分如下。选择创建新的私有命名空间,填写服务发现名称以便消费端使用

4. 下一步后创建服务

5. 点击查看服务,可以看到 ECS 这里显示服务在运行,在 ECS 的服务详细信息里,可以看到服务发现的配置信息。

  • Service discovery endpoint    ECS-Service-Discovery.local-1
  • Service discovery name          ECS-Service-Discovery
  • Namespace                                local-1 (PRIVATE)

6. 找到 Route53 服务,Hosted Zone 的 Record Sets,可以看到服务 endpoint 和对应的两个 Task 的内网 IP 地址。

 

参考文档链接:

涉及服务背景介绍:

Amazon Elastic Container Service (Amazon ECS) 是一种高度可扩展的高性能容器编排服务,支持  Docker 容器,让您可以在 AWS 上轻松运行和扩展容器化应用程序。使用 Amazon ECS,您不需要安装和操作自己的容器编排软件,不需要管理和扩展虚拟机集群,也不需要在这些虚拟机上调度容器。

通过各种简单的 API 调用,您可以启动和停止支持 Docker 的应用程序、查询应用程序的完整状态,并使用 IAM 角色、安全组、负载均衡器、Amazon CloudWatch Events、AWS CloudFormation 模板和 AWS CloudTrail 日志等多种常用功能。

Amazon Route 53 是一种可用性高、可扩展性强的云域名系统 (DNS)Web 服务。其旨在为开发人员和企业提供一种非常可靠且经济高效的方式,可以把名称 (例如 www.example.com) 转换为计算机用于互相连接的数字 IP 地址 (例如 192.0.2.1),从而将最终用户路由到 Internet 应用程序。Amazon Route 53 也与 IPv6 完全兼容。

Amazon Route 53 高效地将用户请求连接到 AWS 中运行的基础设施,例如 Amazon EC2 实例、Elastic Load Balancing 负载均衡器或 Amazon S3 存储桶,还可以将用户路由到 AWS 外部的基础设施。您可以使用 Amazon Route 53 配置 DNS 运行状况检查以将流量路由到正常的终端节点,或者独立监控应用程序及其终端节点的运行状况。Amazon Route 53 Traffic Flow 让您可以通过多种路由类型 (包括基于延迟的路由、Geo DNS、临近地理位置路由和加权轮询) 轻松管理全球流量,所有的路由类型都可与 DNS 故障转移进行组合,以实现各种低延迟容错架构。利用 Amazon Route 53 Traffic Flow 简单的可视化编辑器,您可以轻松管理如何将终端用户路由到应用程序的终端节点,无论是在单个 AWS 区域还是在分布于全球的区域都可实现。Amazon Route 53 还提供域名注册功能 – 您可以购买和管理域名(例如 example.com),Amazon Route 53 将自动为您的域配置 DNS 设置。

郭威

目前在AWS负责推广针对初创企业的最佳云计算架构实践。具有近10年软件设计研发,存储,容器与云计算方案经验。曾任某跨国外企高级研发经理与售前经理,在广电视频行业,金融行业等方面有丰富的云计算经验。后加入某容器创业公司任产品研发与容器云方案工作。现致力于容器服务与Devops等方向的学习与研究。