写点什么

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

  • 2019-10-25
  • 本文字数:3987 字

    阅读完需:约 13 分钟

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 资源量以及您的服务所执行的查找查询量付费,包括您创建的每个命名空间。服务运行状况检查不发生额外的费用。有关定价的更多信息,请参阅[](http://docs.aws.amazon.com/AmazonECS/latest/developerguide/service-discovery.html#service-discovery-pricing)。 现在,使用 AWS Fargate 或 EC2 启动类型及 awsvpc 联网模式的 Amazon ECS 任务均可使用服务发现功能。
_您可以在所有提供 Amazon ECS 和 Amazon Route 53 自动命名服务的 AWS 区域使用 Amazon ECS 服务发现功能,包括美国东部 (弗吉尼亚北部)、美国东部 (俄亥俄)、美国西部 (俄勒冈) 和欧洲 (爱尔兰) 区域。有关 AWS 区域和服务的更多信息,请查看 [](https://amazonaws-china.com/cn/about-aws/global-infrastructure/regional-product-services/)。_
## 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界面创建任务定义模版
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/1-1024x505.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/1.jpg)
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/2-1024x478.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/2.jpg)
_\* 注意目前服务发现只支持 awsvpc 模式,连接什么是 awsvpc 请查看这个[](https://docs.aws.amazon.com/zh_cn/AmazonECS/latest/developerguide/task-networking.html)。_
#### 2. 创建服务
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/3-1024x579.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/3.jpg)
#### 3. 下一步,填写网络,安全相关设置后,在服务发现部分如下。选择创建新的私有命名空间,填写服务发现名称以便消费端使用
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/4-1024x728.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/4.jpg)
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/5-1024x644.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/5.jpg)
#### 4. 下一步后创建服务
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/6-1024x545.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/6.jpg)
#### 5. 点击查看服务,可以看到 ECS 这里显示服务在运行,在 ECS 的服务详细信息里,可以看到服务发现的配置信息。
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/7-1024x382.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/7.jpg)
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/8-1024x363.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/8.jpg)
* 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 地址。
[](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/9-1024x481.jpg)](https://d2908q01vomqb2.awsstatic-china.com/472b07b9fcf2c2451e8781e944bf5f77cd8457c8/2018/05/02/9.jpg)


_参考文档链接:_
* [](https://docs.aws.amazon.com/zh_cn/AmazonECS/latest/developerguide/Welcome.html)* [](https://docs.aws.amazon.com/zh_cn/AmazonECS/latest/developerguide/service-discovery.html):包括服务发现介绍,服务发现注意事项,定价等信息。
_涉及服务背景介绍:_
Amazon Elastic Container Service (Amazon ECS) 是一种高度可扩展的高性能[](https://amazonaws-china.com/cn/containers/)编排服务,支持 [](https://amazonaws-china.com/cn/docker/) 容器,让您可以在 AWS 上轻松运行和扩展容器化应用程序。使用 Amazon ECS,您不需要安装和操作自己的容器编排软件,不需要管理和扩展虚拟机集群,也不需要在这些虚拟机上调度容器。
通过各种简单的 API 调用,您可以启动和停止支持 Docker 的应用程序、查询应用程序的完整状态,并使用 IAM 角色、安全组、负载均衡器、Amazon CloudWatch Events、AWS CloudFormation 模板和 AWS CloudTrail 日志等多种常用功能。
Amazon Route 53 是一种可用性高、可扩展性强的[](https://amazonaws-china.com/cn/route53/what-is-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 等方向的学习与研究。


本文转载自 AWS 技术博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/amazon-ecs-service-discovery-new-start-method/


2019-10-25 08:00853

评论

发布
暂无评论
发现更多内容

跟着卷卷龙一起学Camera--LTM

卷卷龙

ISP 9月月更

INFINI 产品更新啦 20220923

极限实验室

elasticsearch console Gateway infini 极限实验室

[Spring Framework]AOP初识

十八岁讨厌编程

aop 后端开发 9月月更

速刷html一周目(下)

吉师职业混子

9月月更

峰会倒计时1天!九位行业大咖邀您共启极速统一的数据分析新范式

StarRocks

【Jvm】Jvm类加载机制

石臻臻的杂货铺

JVM 9月月更

每日算法刷题Day16-和为S的两个数字、数字排列、二进制中1的个数

timerring

算法题 9月月更

[Spring Framework]AOP经典案例、AOP总结

十八岁讨厌编程

Java 后端开发 9月月更

Web3.0 杂谈 -#003(49/100)

hackstoic

Web3.0

Chrome操作指南——入门篇(十一)network

Augus

Chrome开发者工具 9月月更

WorkPlus移动办公系统:打造安全专属、统一业务与运营的企业门户

BeeWorks

使用 NVIDIA CloudXR 从 Google Cloud 流式传输 VR 和 AR 内容

3DCAT实时渲染

AI走向何方?我们在GTC 2022看到了这些趋势

脑极体

金九银十必备!这份java面经让你轻松拿下45kOffer

Java-fenn

Java 程序员 面试 java面试 Java面试题

优化帮助中心需要做到以下几点

Baklib

产品 帮助中心 在线设计

Baklib|怎样编写内嵌式的帮助文档?

Baklib

产品 产品经理 企业 帮助文档 在线设计

速刷html一周目(上)

吉师职业混子

9月月更

2022-09-23:整数数组 stations 表示 水平数轴 上各个加油站的位置。给你一个整数 k 。 请你在数轴上增设 k 个加油站, 新增加油站可以位于 水平数轴 上的任意位置,而不必放在整数

福大大架构师每日一题

算法 rust 福大大

企业选择局域网即时通讯软件的必要性是什么?

BeeWorks

《软件开发的201个原则》思考:6. 低可靠性比低效率更糟糕

非晓为骁

个人成长 软件工程能力 高质量

Chrome操作指南——入门篇(十二)color picker(颜色选择器)

Augus

Chrome开发者工具 9月月更

FAQ需要有哪些功能?哪些注意事项

Baklib

产品 产品经理 客户服务 FAQ

我也不想学之PHP系列(1)

吉师职业混子

9月月更

Github最新Java面试1658核心讲,助力百人入大厂!

Java-fenn

Java 编程 程序员 java面试 Java面试题

Chrome操作指南——入门篇(十三)element小技巧

Augus

Chrome开发者工具 9月月更

关于 Angular 应用 tsconfig.json 中的 target 属性

汪子熙

typescript 前端开发 angular web开发 9月月更

[Javaweb]JSON

十八岁讨厌编程

json 后端开发 9月月更

2021年中国自然语言处理软件及服务市场规模超200亿,市场保持高速增长,竞争格局远未稳定

易观分析

自然语言处理 市场

开发者有话说|在内卷中不断成长

timerring

9月月更 开发者有话说

培养技能、增强信心、 获得亚马逊云科技认证

亚马逊云科技 (Amazon Web Services)

培训与认证

疫情时代下,线上协同办公成时下热点

Baklib

远程办公 企业 协同办公 在线设计

Amazon ECS 服务发现全新启用方法_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章