

本文属于机器翻译版本。若本译文内容与英语原文存在差异，则一律以英文原文为准。

# 其他部署服务
<a name="additional-deployment-services"></a>

## 
<a name="additional-s3"></a>

 [亚马逊简单存储服务](https://aws.amazon.com/s3/) (Amazon S3) 可用作静态内容和单页应用程序 (SPA) 的 Web 服务器。与 Amazon CloudFront 相结合，可以提高静态内容交付的性能，使用 Amazon S3 可以成为部署和更新静态内容的简单而强大的方法。有关这种方法的更多详细信息可以在 AWS白皮书上的 “[托管静态网站”](https://docs.aws.amazon.com/whitepapers/latest/build-static-websites-aws/build-static-websites-aws.html) 中找到。

## AWS Proton
<a name="additional-proton"></a>

 [AWS Proton](https://aws.amazon.com/proton/) 是一项完全托管的服务，可简化并自动化部署和管理微服务和基于容器的应用程序的过程。它提供了统一、一致的部署体验，可与常用 DevOps 工具和服务集成，从而更易于管理和简化应用程序开发。Proton 使开发人员能够定义和创建应用程序组件，例如基础架构、代码和管道，作为可重复使用的模板。这些模板可用于创建多个环境，例如开发、测试和生产，并且可以在团队或组织之间共享。这种方法有助于降低部署和管理微服务和基于容器的应用程序的复杂性，这可能既耗时又容易出错。

 AWS Proton 为常见的微服务类型（例如 Web 应用程序和数据库）提供了预先构建的模板 APIs，可以对其进行自定义以满足特定需求。它还与 AWS CodePipeline、AWS 和 AWS 等常用 DevOps 工具集成 CodeBuild，以实现持续集成和部署 (CI/CD) 工作流程。 CodeCommit

 通过使用 AWS Proton，开发人员可以减少部署和管理微服务和基于容器的应用程序所需的时间和精力。这种方法使团队能够专注于开发和改进应用程序，而不必将时间花在部署和管理流程上。

## AWS App2Container
<a name="additional-app2container"></a>

 [AWS App2Container](https://aws.amazon.com/app2container)是一款命令行工具，用于将 Java 和.NET Web 应用程序迁移到容器格式并使其现代化。App2Container 分析并生成在裸机、虚拟机、Amazon EC2 实例或云中运行的应用程序清单。您只需选择要容器化的应用程序，App2Container 就会将应用程序工件和已识别的依赖项打包到容器镜像中，配置网络端口，然后生成 ECS 任务和 Kubernetes 容器定义。App2Container 可识别虚拟机中运行的支持的 ASP.NET 和 Java 应用程序，以生成环境中所有应用程序的全面清单。App2Container 可以容器化在 Windows 上的 IIS 中运行的 ASP.NET Web 应用程序或者在 Linux、独立服务器或应用程序服务器（例如 Apache Tomcat、Springboot JBoss、IBM Websphere 和 Oracle Weblogic）上运行的 Java 应用程序。

## AWS Copilot
<a name="additional-copilot"></a>

 [AWS Copilot](https://aws.amazon.com/containers/copilot/) 是一个命令行界面 (CLI)，您可以使用它在 AWS 上快速启动和管理容器化应用程序。它简化了在 Amazon ECS、Fargate 和 App Runner 上运行应用程序。AWS Copilot 目前支持 Linux、macOS 和 Windows 系统。Copilot 使您能够使用诸如负载平衡的 Web 服务之类的服务模式来配置基础架构，部署到测试或生产等多个环境，甚至使用 AWS CodePipeline 发布管道进行自动部署。

## AWS Serverless Application Model
<a name="additional-aws-sam"></a>

 [AWS Serverless Application Model](https://aws.amazon.com/serverless/sam/)(AWS SAM) 是一个用于构建无服务器应用程序的开源框架。它提供了用于表达函数 APIs、数据库和事件源映射的速记语法。每个资源只需几行，您就可以定义所需的应用程序并使用 YAML 对其进行建模。在部署过程中，SAM 将 SAM 语法转换并扩展为 AWS CloudFormation 语法，使您能够更快地构建无服务器应用程序。

 AWS SAM CLI 是一种开源命令行工具，可以轻松地在 AWS 上开发、测试和部署无服务器应用程序。它是一个命令行界面，用于使用 AWS SAM 规范构建无服务器应用程序，该规范是 AWS 的扩展。 CloudFormation

 AWS SAM CLI 使开发人员能够在本地定义和测试他们的无服务器应用程序，然后再将其部署到 AWS。它提供了一个模拟 AWS Lambda 和 API Gateway 的本地测试环境，使开发人员能够在将代码和配置部署到云端之前对其进行测试。

 AWS SAM CLI 还包括各种有用的功能，例如自动代码部署、日志记录和调试功能。它使开发人员能够使用单个命令构建、打包和部署应用程序，从而减少部署和管理无服务器应用程序所需的时间和精力。

 此外，AWS SAM CLI 还支持各种编程语言，包括 Node.js、Python、Java 和.NET Core 等。这允许开发人员使用他们首选的编程语言和工具来构建和部署他们的无服务器应用程序。

 AWS SAM CLI 可与其他 AWS 服务（例如 AWS CodePipeline 和 AWS）集成 CodeBuild，为无服务器应用程序提供全自动和集成的 CI/CD 管道。它还允许开发人员在其无服务器应用程序中使用其他 AWS 服务，例如 Amazon S3、Amazon DynamoDB 和 Amazon SNS。

## AWS Cloud Development Kit (AWS CDK)
<a name="additional-cdk"></a>

 [AWS Cloud Development Kit (AWS CDK)](https://aws.amazon.com/cdk/)(AWS CDK) 是一个开源软件开发框架，用于使用现代编程语言将云基础设施定义为代码，并通过 AWS 进行部署 CloudFormation。AWS Cloud Development Kit (AWS CDK) 使用常用编程语言对应用程序进行建模，加速云开发。借助 AWS CDK，您可以利用编程语言的强大表现力，在云中构建可靠、可扩展、经济实惠的应用程序。

 可以将 AWS CDK 想象成一个以开发人员为中心的工具包，它利用现代编程语言的全部力量将您的 AWS 基础设施定义为代码。运行 AWS CDK 应用程序时，它们会编译成完整的 CloudFormation JSON/YAML 模板，然后将其提交给服务进行预配置。 CloudFormation 由于 AWS CDK 可以利用 CloudFormation，因此您仍然可以享受安全部署、自动回滚和漂移检测等所有好处 CloudFormation 。

 这种方法有许多好处，包括：
+  使用高级结构进行构建，这些结构可自动为您的 AWS 资源提供合理、安全的默认值，从而用更少的代码定义更多的基础设施。
+  使用诸如参数、条件、循环、组合和继承之类的编程习惯，根据 AWS 和其他机构提供的构建块对系统设计进行建模。
+  将基础架构、应用程序代码和配置全部放在一个地方，确保在每个里程碑上都有一个完整的、可在云端部署的系统。
+  采用软件工程实践，例如代码审查、单元测试和源代码控制，使您的基础架构更加强大。
+  AWS Solutions Constructs 是 AWS CDK 的开源库扩展。AWS Solutions Constructs 为您提供了一系列经过审查的多服务架构模式，这些模式是使用 AWS Well-Architected Framework 建立的最佳实践构建的。

 AWS Serverless 应用程序模型和 AWS CDK 都将 AWS 基础设施抽象为代码，使您可以更轻松地定义云基础设施。AWS SAM 专门关注无服务器用例和架构，允许您在紧凑的声明式 JSON/YAML 模板中定义基础设施。AWS CDK 涵盖所有 AWS 服务，允许您使用现代编程语言定义云基础设施 

## 亚马逊 EC2 Image Builder
<a name="additional-ec2-image-builder"></a>

 [EC2 Image Builder](https://aws.amazon.com/image-builder/) 简化了在 AWS 或本地使用的虚拟机和容器映像的构建、测试和部署。保留虚拟机和容器镜像 up-to-date可能非常耗时、资源密集且容易出错。目前，客户要么手动更新和快照，要 VMs 么让团队构建自动化脚本来维护映像。Image Builder 通过提供简单的图形界面、内置的自动化功能 up-to-date和 AWS 提供的安全设置，显著减少了保护图像和安全的工作量。使用 Image Builder，无需执行手动步骤来更新映像，也不必构建自己的自动化管线。除了用于创建、存储和共享图像的底层 AWS 资源的成本外，Image Builder 不收取任何费用。

 EC2 Image Builder 可以简化创建和管理用于亚马逊 EC2、容器和本地服务器的自定义映像的流程，从而简化在 AWS 上的部署。该服务提供了一种简化而灵活的方法来创建和管理自定义映像，其自动生成管道使您能够简化映像的创建和管理流程。

 EC2 Image Builder 提供了一个用户友好的界面，它抽象了大部分底层基础架构管理，使开发人员可以更轻松地创建和管理自定义映像。借 EC2 助 Image Builder，开发人员可以指定他们想要在映像中包含的操作系统、应用程序和软件包，该服务可以自动生成和测试映像的过程，包括更新、补丁和安全修复。自动生成管道使开发人员能够简化映像创建和管理流程，从而减少手动创建和测试映像所需的时间和精力。这有助于提高一致性，减少错误，并确保图像安全 up-to-date、合规。

 以下是 EC2 Image Builder 的一些优点：
+  简化映像创建： EC2 Image Builder 提供了一种简化而灵活的方式来创建用于亚马逊 EC2、容器和本地服务器的自定义映像。这有助于减少创建和维护自定义映像所需的时间和精力，并使您能够专注于部署的其他方面，例如应用程序开发和测试。
+  自动映像生成管道： EC2 Image Builder 提供用于构建、测试和部署自定义映像的自动管道，这有助于简化映像创建和管理流程。这有助于确保您的图像安全 up-to-date、合规，并减少手动创建和测试图像所需的时间和精力。
+  与 AWS 服务集成： EC2 Image Builder 与其他 AWS 服务（例如亚马逊弹性容器注册表 (ECR) 和亚马逊 Elastic Kubernetes Service (EKS)）集成，使您能够构建用于容器的自定义映像。这有助于简化容器构建和部署过程，使您能够构建包含应用程序、库和配置的自定义映像。
+  灵活创建映像： EC2 Image Builder 提供了一种创建自定义映像的灵活方式，使您能够指定要在映像中包含的操作系统、应用程序和软件包。这有助于确保您的映像根据您的特定用例和要求量身定制，并降低部署过程中出现错误或不兼容的风险。
+  提高图像安全性和合规性： EC2 Image Builder 使您能够自动进行图像测试，包括漏洞和合规性扫描，以确保您的图像安全合规。这有助于降低安全漏洞的风险并提高合规性，并使您能够放心地部署应用程序。