写点什么

使用 AWS CDK 轻松构建云原生应用之 EKS 平台(三)

  • 2019-12-20
  • 本文字数:2148 字

    阅读完需:约 7 分钟

使用 AWS CDK 轻松构建云原生应用之 EKS 平台(三)

AWS CDK V.S. AWS CloudFormation

熟悉 AWS 或者云计算的朋友一定都知道AWS CloudFormation。我们创建一个描述所有 AWS 资源的 JSON 格式或者 YAML 格式的模板,通过 AWS CloudFormation 可以快速地对这些资源进行建模和设置,并且可以方便地对资源进行管理。一切都可以自动化完成而无需手动操作。很多 AWS 客户已经采用 CloudFormation 实现了基础设施即代码(Infrastructure as Code)。


但是使用时会发现,从零开始写模板还是一件繁琐的工作,尤其是针对于同一种 AWS 服务,模板里的大部分内容是相同的,只是在一些属性和参数上有所差别。曾经在向一个客户演示完 CloudFormation 后,客户抛出一个问题:有没有一个自动生成模板的工具?这真是一个好问题!软件的本质就是不断抽象并简化工作。所以 AWS 推出了云开发工具包 AWS Cloud Development Kit,简称 AWS 。这是一种开源软件开发框架,提供一种更高层级的抽象,使用者可以使用熟悉的编程语言模拟和预置云应用程序资源(construct library)。而 CDK 的底层会自动生成 CloudFormation 模板,然后调用 CloudFormation 来完成所有的资源创建工作。AWS 的 CDK 开发团队基于 CloudFormation 构建了 AWS 资源的 L2 construct,完成从对象定义到 CFN 模板的转换。所以采用 CDK 比采用 CloudFormation 的代码会少很多很多,大大简化工作量。另外特别要强调的,CDK 是一个完全开源的项目!(https://github.com/aws/aws-cdk)也就是说只要你愿意,完全可以向里面贡献你的代码!在今年的AWS re:Invent 上有一个 session OPN205_R就是介绍如何向 AWS CDK 贡献代码,大家可以看这个视频了解.


关于 CDK 我们在这篇文章里不做更多介绍啦,具体可以参考 AWS 的官方网站,上面有很详细的介绍:https://aws.amazon.com/cn/cdk/

AWS CDK 的实践之路

在近期的一个项目里,我们帮助客户使用 CDK 轻松快速的构建了整套云原生应用架构,包括 Amazon Elastic Kubernetes Service(简称 EKS)平台,应用架构,监控日志,调用链跟踪以及 CICD 等。我们将会作为一个系列介绍。这篇文章是第一篇,介绍如何构建基础网络架构和 EKS 平台。搭建好的架构如下图:



以下是我们的具体步骤:

1.安装 CDK

可以按照 AWS 的官方文档介绍来安装 CDK:https://docs.aws.amazon.com/cdk/latest/guide/getting_started.html


安装好后跑一下命令,就可以看到 CDK cli 已经安装完成了:


2.初始化我们的应用程序

该命令在一个 AWS 账号下从零创建所有应用架构依赖的组件,我们给创建好的应用命名为 cdk-repo:



我们的应用程序都是使用 Python 编写的。除了 Python,CDK 目前还支持 Javascript, Typescript,Python,.NET,Java 并且全都 GA 了,所以你可以方便的选用自己熟悉的语言编写。

3.创建基础网络架构

在任何一个 AWS 账号下的一个全新区域中,都需要搭建基础的网络设施,包括 AWS Virtual Private Cloud(简称 VPC)、子网、堡垒机、NAT 等基本组件,为应用运行准备基础环境。

3.1 创建基础网络架构

我们通过以下一段代码,可以方便地创建出一个 AWS 上标准的基础网络架构,包括:一个指定了 CIDR 和名字的 VPC,一个 NAT Gateway,以及每个 Availability Zone(简称 AZ)中的三个子网,分别是:公有子网——允许所有出入公网;私有子网——没有直接的出入公网的路由,但是可以通过堡垒机访问私有子网内的资源,可以通过 NAT gateway 出到公网;保护子网——没有出入公网的路由,通常用于数据库。



注意:如果你是在 2AZ 的区域中运行该代码,会创建 32=6 个子网,如果在 3AZ 的区域中运行该代码,会创建 33=9 个子网。该代码可以自动适配到 AZ 的数量。

3.2 为 VPC 和子网打 tag

如果你在 AWS 上创建过 EKS,应该了解 EKS 对它所在的 VPC 和子网的 tag 有所要求。所以我们采用以下代码打 tag:


3.3 创建堡垒机

CDK 中已经有实现的 construct,可以快速的创建堡垒机。但是我为了使用自己预创建的 key,所以采用 ec2 instance 的方式来创建堡垒机,采用以下代码:



可以看到,堡垒机的安全组设置也是非常方便,用两行代码就可以允许任何 ip 的 ssh 访问。


注意:建议针对该堡垒机开启 VPC flow log,可以记录进出该堡垒机的网络流量,做到安全监控。由于 L2 construct 的 instance 不支持设置 Elastic Network Interface(ENI),从而无法开启 VPC flow log,所以需要基于 CfnInstance 完成。

3.4 传递参数

我们会对整个应用进行模块化编排,将不同的模块划分到不同的 Stack,方便我们更好的组织、管理以及复用代码。我们会在最后一篇文章介绍整体的 Stack 编排和设计。这里只介绍我们将 VPC 名称和堡垒机的安全组作为参数传递给其他 Stack,包括 EKS Stack。


3.5 设置 Stack 入口

我们在 app.py 中设置用于基础网络架构的 Stack 的入口,也就是 LandingzoneStack:


3.6 查看 Stack

在命令行中通过以下命令查看我们刚才创建的 stack:



通过命令 cdk synth 可以打印出生成的 CloudFormation 模板,下面截图中只展示了模板的一部分,可以看到短短的几句 CDK 应用可以生成好几十行的模板,所以 CDK 对比 CloudFormation 非常高效。通常我们打出 CloudFormation 模板只是为了调试。



本文转载自 AWS 技术博客。


原文链接:https://amazonaws-china.com/cn/blogs/china/using-aws-cdk-easily-build-eks-platform-cloud-native-application/


2019-12-20 15:152604

评论

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

SD-WAN降低网络运维难度的三大关键技术

Ogcloud

SD-WAN 企业网络 SD-WAN组网 SD-WAN服务商 SDWAN

建议有这些需求的企业部署SD-WAN!

Ogcloud

SD-WAN 企业组网 SD-WAN组网 SD-WAN服务商 SDWAN

聚道云软件连接器:助力企业财务效率提升的成功案例

聚道云软件连接器

案例分享

提质增效|大型汽车制造业运维精细化管理建设实战

云智慧AIOps社区

智能运维 运维管理

PLM系统全面指南

爱吃小舅的鱼

产品管理 PLM

ETL中如何自定义规则

RestCloud

数据同步 ETL 数据规则

跨界创新,数字赋能:探索低代码平台的多元化应用场景

优秀

低代码 低代码开发平台 低代码平台 低代码应用场景

聚道云助IT公司破解数据同步难,高效转型新利器!

聚道云软件连接器

案例分享

Node.js环境下淘宝商品详情接口开发实践

tbapi

淘宝商品详情数据接口 淘宝数据采集

网站安全方面,漏洞扫描VSS能提供哪些帮助

德迅云安全杨德俊

使用EasyRec快速构建推荐模型

阿里云天池

阿里云

负载均衡:实现高效稳定的网络服务

gogo

云智慧发布对象关系型数据库CloudPanguDB,打破传统技术壁垒

云智慧AIOps社区

数据库

【详细注释+流程讲解】基于深度学习的文本分类 TextCNN

阿里云天池

机器学习 阿里云

天池医疗AI大赛[第一季] Rank8解决方案[附TensorFlow/PyTorch/Caffe实现方案]

阿里云天池

人工智能 阿里云

云智慧:拥抱AI算法驱动的智能运维服务创新引擎

云智慧AIOps社区

人工智能 自然语言处理 算法

“不知今夕是何年”的周基年解法|得物技术

得物技术

Java 程序员 前端 后端 企业号 4 月 PK 榜

从 Redis 开源协议变更到 ES 国产化:一次技术自主的机遇 记某客户的一次无缝数据迁移

极限实验室

console Gateway easysearch

inBuilder低代码平台新特性推荐-第十七期

inBuilder低代码平台

开源 低代码

【机器学习入门】拥抱人工智能,从机器学习开始

阿里云天池

机器学习 阿里云

6E DBDC 4T4R QCN6224 QCN9274 QCN6274 WiFi7 Lower Power Consumption Network Card

wallyslilly

qcn9274 qcn6274 QCN6224

Rank4 NLP新闻文本分类-开源代码+经验分享@惊鹊

阿里云天池

机器学习 阿里云

架构实战营 - 模块四作业

满心

架构实战营

Paper Digest | GPT-RE:基于大语言模型针对关系抽取的上下文学习

可信AI进展

语言模型 #大模型

《信息技术服务 智能运维 第2部分:数据治理》国家标准2024年第一次线下编写会议成功召开

云智慧AIOps社区

运维

知识图谱在五大智能领域的应用

悦数图数据库

知识图谱

精挑细选:哪款PLM软件最适合您的企业?全面对比10大热门产品

爱吃小舅的鱼

项目管理 产品经理 PLM软件

测试测试从

delete is create

前十名单公布|OpenTiny 前端 Web 应用开发挑战赛初赛结果揭晓~

OpenTiny社区

开源 前端 低代码 组件库

无需注册即可使用 ChatGPT;Poe 创始人:大模型幻觉是创业公司的机会丨RTE 开发者日报 Vol.176

声网

被 AI 写的游戏代码砸中是什么感觉 | 10 分钟打造你的超级 AI 编码助手

阿里云云效

阿里云 云原生 通义灵码

使用 AWS CDK 轻松构建云原生应用之 EKS 平台(三)_语言 & 开发_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章