HarmonyOS开发者限时福利来啦!最高10w+现金激励等你拿~ 了解详情
写点什么

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:00663

评论

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

低代码开发平台核心功能设计——组件自定义交互实现

徐小夕

大前端 编辑器 H5 大屏可视化 lowcode

涨薪神作!华为内部操作系统与网络协议笔记爆火,Java程序员有福了

Java架构之路

Java 程序员 面试 编程语言

可以解除程序员中年危机的职业规划

Java架构师迁哥

记不住Spring中Scheduled中的Cron语法?让我们看看源码吧

AI乔治

Java spring 编程 架构

甲方日常 48

句子

工作 随笔杂谈 日常

代码简易调试方法.md

Albert

Java LeetCode 调试

什么?美团T9首发内部JVM高级特性笔记,看完差距不止一点

小Q

Java 学习 程序员 架构 面试

这份笔记我必啃完!美团T9首发内部JVM高级特性笔记,差距不止一点点

Java架构追梦

Java 源码 架构 面试 JVM

5G为数字化转型插上翅膀

CECBC

5G网络安全

O'Reilly出版社又一经典之作——Python设计模式

计算机与AI

Python

Spring bean 加载顺序导致的 bug 问题

AI乔治

Java 架构 Spring Boot

当人脸识别对准执法者,AI的应用边界博弈

脑极体

【T1543.003】利用 ACL 隐藏恶意 Windows 服务

比伯

Java 大数据 编程 架构 计算机

一个技术总监的忠告:精通那么多技术,你为何还是受不到重用?

四猿外

程序人生 技术管理 加薪 职场成长 源码阅读

cglib入门后篇

Rayjun

Java cglib

Rethink:多版本文件的命名细节

小匚

团队 随笔杂谈

2020双11:每秒58.3万笔!阿里云又扛住了!

云计算 互联网 运维 云原生 科技

如何应对大促流量洪峰?揭秘京东技术人的备战手册

京东科技开发者

云计算 大数据 亿级流量

从零到千万用户,我是如何一步步优化MySQL数据库的?

冰河

数据库 架构 性能优化 分布式数据库 分布式存储

架构师训练营第 1 期第 8 周学习总结

好吃不贵

极客大学架构师训练营

数字人民币都来了 黄金还有什么用?

CECBC

数字货币

深度解析ThreadLocal原理

AI乔治

Java 架构 线程 ThreadLocal

如何预防工业物联网中的恶意攻击?

VoltDB

大数据 数据分析 5G 工业互联网

「Java并发编程」从源码分析几道必问线程池的面试题?

Java架构师迁哥

实时指挥调度的发展和优势

anyRTC开发者

ios android 音视频 WebRTC RTC

微信视频号强制置顶朋友圈:盈利不可牺牲用户体验

石头IT视角

当我们在讨论实时性的时候,我们在讨论什么?

VoltDB

数据分析 5G 工业互联网

区块链产业,怎样“链”住未来?

CECBC

区块链

甲方日常 47

句子

工作 随笔杂谈 日常

靠脑机接口“隔空探物”,大脑植入芯片可实现“心灵感应”

脑极体

Reactor中的Thread和Scheduler

程序那些事

响应式编程 reactor 多线程 程序那些事 reactivex

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