快速入门:将 ASP.NET 应用程序部署到 Elastic Beanstalk - AWS Elastic Beanstalk

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

快速入门:将 ASP.NET 应用程序部署到 Elastic Beanstalk

本快速入门教程将引导您完成创建 ASP.NET 应用程序并将其部署到 AWS Elastic Beanstalk 环境的过程。

注意

此快速入门教程用于演示目的。请勿将本教程中创建的应用程序用于生产流量。

您的 AWS 账户

如果您还不是AWS客户,则需要创建一个AWS账户。注册之后,您将能够访问 Elastic Beanstalk 以及您可能需要的其他AWS服务。

如果您已有 AWS 账户,则您可以继续 先决条件

注册 AWS 账户

如果您还没有 AWS 账户,请完成以下步骤来创建一个。

注册 AWS 账户
  1. 打开 https://portal.aws.amazon.com/billing/signup

  2. 按照屏幕上的说明进行操作。

    在注册时,将接到一通电话,要求使用电话键盘输入一个验证码。

    当您注册 AWS 账户时,系统将会创建一个 AWS 账户根用户。根用户有权访问该账户中的所有 AWS 服务 和资源。作为安全最佳实践,请为用户分配管理访问权限,并且只使用根用户来执行需要根用户访问权限的任务

注册过程完成后,AWS 会向您发送一封确认电子邮件。在任何时候,您都可以通过转至 https://aws.amazon.com/ 并选择我的账户来查看当前的账户活动并管理您的账户。

创建具有管理访问权限的用户

注册 AWS 账户 后,请保护好您的 AWS 账户根用户,启用 AWS IAM Identity Center,并创建一个管理用户,以避免使用根用户执行日常任务。

保护您的 AWS 账户根用户
  1. 选择根用户并输入您的 AWS 账户电子邮件地址,以账户拥有者身份登录 AWS Management Console。在下一页上,输入您的密码。

    要获取使用根用户登录方面的帮助,请参阅《AWS 登录 用户指南》中的以根用户身份登录

  2. 为您的根用户启用多重身份验证 (MFA)。

    有关说明,请参阅《IAM 用户指南》中的为 AWS 账户 根用户启用虚拟 MFA 设备(控制台)

创建具有管理访问权限的用户
  1. 启用 IAM Identity Center。

    有关说明,请参阅《AWS IAM Identity Center 用户指南》中的启用 AWS IAM Identity Center

  2. 在 IAM Identity Center 中,为用户授予管理访问权限。

    有关如何使用 IAM Identity Center 目录 作为身份源的教程,请参阅《AWS IAM Identity Center 用户指南》中的使用默认的 IAM Identity Center 目录 配置用户访问权限

以具有管理访问权限的用户身份登录
  • 要使用您的 IAM Identity Center 用户身份登录,请使用您在创建 IAM Identity Center 用户时发送到您的电子邮件地址的登录网址。

    要获取使用 IAM Identity Center 用户登录方面的帮助,请参阅《AWS 登录 用户指南》中的登录 AWS 访问门户

将访问权限分配给其他用户
  1. 在 IAM Identity Center 中,创建一个权限集,该权限集遵循应用最低权限的最佳做法。

    有关说明,请参阅《AWS IAM Identity Center 用户指南》中的创建权限集

  2. 将用户分配到一个组,然后为该组分配单点登录访问权限。

    有关说明,请参阅《AWS IAM Identity Center 用户指南》中的添加组

先决条件

本快速入门教程将引导您使用 Visual Studio 和 AWS Toolkit for Visual Studio 创建“Hello World”应用程序并将其部署到 Elastic Beanstalk 环境。

注意

2024 年 10 月 1 日之后创建的 AWS 账户将暂时需要设置选项才能成功创建新环境。与新账户一样,但仅限于账户尚没有环境的区域,现有账户需要采取相同的操作。有关更多信息,请参阅 启动模板

Visual Studio

要下载和安装 Visual Studio,请按照 Visual Studio 下载页面上的说明进行操作。此示例使用 Visual Studio 2022。在 Visual Studio 安装过程中,选择以下特定项:

  • 工作负载选项卡上 — 选择 ASP.NET 和 Web 开发

  • 单个组件选项卡上 — 选择 .NET Framework 4.8 开发工具.NET Framework 项目和项模板

AWS Toolkit for Visual Studio

要下载和设置 AWS Toolkit for Visual Studio,请按照《AWS Toolkit for Visual Studio 用户指南》的入门主题中的说明进行操作。

步骤 1:创建 ASP.NET 应用程序

接下来,创建一个将部署到 Elastic Beanstalk 环境的应用程序。我们将创建一个“Hello World”ASP.NET Web 应用程序。

创建 ASP.NET 应用程序
  1. 启动 Visual Studio。在文件菜单中,选择新建,然后选择项目

  2. 将显示创建新项目对话框。选择 ASP.NET Web 应用程序(.NET Framework),然后选择下一步

  3. 配置您的新项目对话框中,输入 eb-aspnet 作为您的项目名称。从框架下拉菜单中,选择 .NET Framework 4.8,然后选择创建

    记下项目目录。在此示例中,项目目录为 C:\Users\Administrator\source\repos\eb-aspnet\eb-aspnet

  4. 此时将显示创建新的 ASP.NET Web 应用程序对话框。选择模板。接下来,选择创建

    此时,您已使用 Visual Studio 创建了一个空的 ASP.NET Web 应用程序项目。接下来,我们将创建一个 Web 表单作为 ASP.NET Web 应用程序的入口点。

  5. 项目菜单中,选择添加新项目。在添加新项目页面上,选择 Web 表单并将其命名为 Default.aspx。接下来选择添加

  6. 将以下内容添加到 Default.aspx:

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="eb_aspnet.Default" %> <!DOCTYPE html> <html xmlns="https://www.w3.org/1999/xhtml"> <head runat="server"> <title>Hello Elastic Beanstalk!</title> </head> <body> <form id="body" runat="server"> <div> Hello Elastic Beanstalk! This is an ASP.NET on Windows Server application. </div> </form> </body> </html>

步骤 2:在本地运行应用程序

在 Visual Studio 中,从调试菜单中选择开始调试,以在本地运行应用程序。页面应显示“Hello Elastic Beanstalk! This is an ASP.NET on Windows Server application.”

步骤 3:使用 AWS Toolkit for Visual Studio 部署 ASP.NET 应用程序

按照以下步骤创建 Elastic Beanstalk 环境并将新应用程序部署到其中。

创建环境和部署 ASP.NET 应用程序
  1. 解决方案资源管理器中,右键单击您的应用程序,然后选择发布到 AWS Elastic Beanstalk

  2. 为新的 Elastic Beanstalk 应用程序和环境选择一个名称。

  3. 除此之外,您可以继续使用 Elastic Beanstalk 提供的默认设置,或根据您的喜好修改任何选项和设置。

  4. 检查页上,选择部署。这将打包您的 ASP.NET Web 应用程序并将其部署到 Elastic Beanstalk。

    Elastic Beanstalk 大约需要五分钟来创建您的环境。Elastic Beanstalk 部署功能将监控您的环境,直到部署了新代码的环境变得可用为止。在 Env:<environment name> 选项卡上,您将看到环境的状态。

步骤 4:在 Elastic Beanstalk 上运行应用程序

当创建环境的过程完成时,Env:<environment name> 选项卡将显示有关您的环境和应用程序的信息,包括启动应用程序的域 URL。在此选项卡上选择此 URL 或将其复制并粘贴到您的 Web 浏览器中。

恭喜您!您已使用 Elastic Beanstalk 部署了 ASP.NET 应用程序!

第 5 步:清理

应用程序使用完毕时,您可以在 AWS Toolkit for Visual Studio 中终止您的环境。

终止环境
  1. AWS Explorer 中,展开 Elastic Beanstalk 节点和应用程序节点。右键单击应用程序环境,选择 Terminate Environment(终止环境)。

  2. 当系统提示时,选择以确认要终止该环境。Elastic Beanstalk 需要几分钟时间才能终止环境中运行的 AWS 资源。

适合您的应用程序的 AWS 资源

您刚刚创建了一个单实例应用程序。它可用作带有单个 EC2 实例的简单示例应用程序,因此不需要负载平衡或自动扩缩。对于单实例应用程序,Elastic Beanstalk 创建以下 AWS 资源:

  • EC2 实例 - 配置来在您选择的平台上运行 Web 应用程序的 Amazon EC2 虚拟机。

    各平台运行一组不同的软件、配置文件和脚本以支持特定的语言版本、框架、Web 容器或其组合。大多数平台使用 Apache 或 nginx 作为在 Web 应用程序前处理 Web 流量的反向代理,向其转发请求、提供静态资产以及生成访问和错误日志。

  • 实例安全组 - 配置为允许端口 80 上的传入流量的 Amazon EC2 安全组。通过此资源,HTTP 流量可以从负载均衡器到达运行您的 Web 应用程序的 EC2 实例。默认情况下,其他端口不允许流量进入。

  • Amazon S3 存储桶 – 使用 Elastic Beanstalk 时创建的源代码、日志和其他构件的存储位置。

  • Amazon CloudWatch 警报 - 用于监控环境中的实例负载的两个 CloudWatch 警报,它们将在负载过高或过低时触发。警报触发后,您的 Auto Scaling 组会扩展或收缩以进行响应。

  • AWS CloudFormation 堆栈 – Elastic Beanstalk 使用 AWS CloudFormation 启动您环境中的资源并传播配置更改。这些资源在您可通过 AWS CloudFormation 控制台查看的模板中定义。

  • 域名 – 一个域名,它以下面的形式路由到您的 Web 应用程序:subdomain.region.elasticbeanstalk.com

Elastic Beanstalk 管理所有这些资源。当您终止环境时,Elastic Beanstalk 会终止其包含的所有资源。

后续步骤

有了运行应用程序的环境以后,您随时可以部署新的应用程序版本或不同的应用程序。部署新应用程序版本非常快,因为不需要配置或重新启动 EC2 实例。您还可以使用 Elastic Beanstalk 控制台探索新环境。有关详细步骤,请参阅本指南入门一章中的探索您的环境

尝试更多教程

如果您想尝试包含不同示例应用程序的其他教程,请参阅 .NET Core on Windows 快速入门

部署一到两个示例应用程序并准备好开始在本地开发和运行 ASP.NET 应用程序后,请参阅 设置 .NET 开发环境

使用 Elastic Beanstalk 控制台进行部署

您还可以使用 Elastic Beanstalk 控制台来启动示例应用程序。有关详细步骤,请参阅本指南入门一章中的创建示例应用程序