Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
本文介绍如何配置部署到 Azure App Service 的 Aspire 应用。 Aspire 提供了一种简化的、有意见的方法,用于生成可观察的、生产就绪的云原生应用程序,以及App Service集成,允许你通过代码自定义基础Azure基础结构。
如果尚未将 Aspire 应用部署到App Service,请先参阅 quickstart 指南。
先决条件
- 具有 Azure App Service 托管集成的现有 Aspire 应用。 请参阅 Quickstart:将 Aspire 应用部署到 Azure App Service。
- Aspire.Hosting。Azure。AppService 包已添加到 AppHost project。
了解预配的资源内容
调用 AddAzureAppServiceEnvironment 时,Aspire 默认预配以下Azure资源:
| 资源 | Description |
|---|---|
| App Service Plan | 基于 Linux 的高级 P0V3 托管计划 |
| Azure Container Registry | 用于存储容器映像的基本 SKU 注册表 |
| 用户分配的托管标识 | 在 App Service 和容器注册表之间实现安全访问。 |
| 角色分配 | 分配给托管标识的 ACR 拉取角色 |
这些资源提供将容器化 Aspire 应用部署到Azure App Service所需的基础结构。
连接到现有 App Service 方案
如果您已有 Azure 应用服务计划,您可以连接到该计划,而无需创建新的计划。
AsExisting使用该方法引用现有资源:
var builder = DistributedApplication.CreateBuilder(args);
var existingAppServicePlanName = builder.AddParameter("existingAppServicePlanName");
var existingResourceGroup = builder.AddParameter("existingResourceGroup");
var appServiceEnv = builder.AddAzureAppServiceEnvironment("app-service-env")
.AsExisting(existingAppServicePlanName, existingResourceGroup);
builder.AddProject<Projects.WebApi>("api")
.PublishAsAzureAppServiceWebsite((infra, website) =>
{
// Optional: customize the Azure App Service website here
});
builder.Build().Run();
这种方法在您希望实现以下目标时很有用:
- 跨多个应用程序共享 App Service 计划
- 使用在 Aspire 外部预配的 App Service 计划
- 连接到其他资源组中的资源
将项目发布为 App Service 网站
使用 PublishAsAzureAppServiceWebsite 方法将计算资源部署为 Azure 应用服务网站:
var builder = DistributedApplication.CreateBuilder(args);
var appServiceEnv = builder.AddAzureAppServiceEnvironment("app-service-env");
builder.AddProject<Projects.WebApi>("api")
.PublishAsAzureAppServiceWebsite((infra, website) =>
{
// Optional: customize the Azure App Service website here
});
builder.Build().Run();
在本地开发期间(使用 F5 或 dotnet run 运行时),项目将在本地运行。 当您使用 azd up 发布应用时,该项目会部署为预配环境中的 Azure 应用服务(Azure App Service)网站。
配置应用服务计划的 SKU 和层级
可以使用 ConfigureInfrastructure 方法自定义App Service计划 SKU、层和容量。 此方法允许你访问和修改 Aspire 预配的基础 Azure 资源。
在 AppHost.cs 文件中,配置应用服务环境,并使用自定义计划设置。
using Azure.Provisioning.AppService;
var builder = DistributedApplication.CreateBuilder(args);
builder.AddAzureAppServiceEnvironment("app-service-env")
.ConfigureInfrastructure((infra) =>
{
var plan = infra.GetProvisionableResources().OfType<AppServicePlan>().Single();
plan.Sku = new AppServiceSkuDescription
{
Name = "P1V3",
Tier = "Premium"
};
});
builder.Build().Run();
ConfigureInfrastructure回调可让您直接访问 Azure 预配资源。 在本示例中:
-
GetProvisionableResources()返回正在预配的所有Azure资源。 -
OfType<AppServicePlan>()使用筛选器来获取应用服务计划。 - 然后,可以修改属性,例如
Sku.Name,Sku.Tier和Sku.Capacity(实例数)。
配置 Aspire 仪表板
默认情况下,Aspire 仪表板包含在部署到Azure App Service时,可让你查看已部署的应用程序:
builder.AddAzureAppServiceEnvironment("app-service-env");
// Dashboard is included by default at https://[prefix]-aspiredashboard-[unique string].chinacloudsites.cn
部署的仪表板提供与本地开发相同的体验:查看生产环境的日志、跟踪、指标和应用程序拓扑。
若要禁用仪表板,请执行以下操作:
builder.AddAzureAppServiceEnvironment("app-service-env")
.WithDashboard(enable: false);
配置 Azure Application Insights
启用 Azure Application Insights 以实现全面的监视和遥测:
builder.AddAzureAppServiceEnvironment("app-service-env")
.WithAzureApplicationInsights();
启用后,Aspire 会自动:
- 创建 Log Analytics 工作区。
- 创建 Application Insights 资源。
- 使用连接字符串配置所有 App Service Web 应用。
- 将
APPLICATIONINSIGHTS_CONNECTION_STRING注入到您的应用程序中。
还可以引用现有的 Application Insights 资源:
var insights = builder.AddAzureApplicationInsights("insights");
builder.AddAzureAppServiceEnvironment("app-service-env")
.WithAzureApplicationInsights(insights);
配置应用设置
可以通过将 PublishAsAzureAppServiceWebsite 方法与基础结构配置结合使用,将自定义应用设置添加到App Service应用。
builder.AddProject<Projects.aspire_starter_Web>("webfrontend")
.WithExternalHttpEndpoints()
.WithReference(apiService)
.WaitFor(apiService)
.PublishAsAzureAppServiceWebsite((infra, website) =>
{
website.SiteConfig.AppSettings.Add(new AppServiceNameValuePair
{
Name = "WEBSITE_LOAD_CERTIFICATES",
Value = "*"
});
website.SiteConfig.AppSettings.Add(new AppServiceNameValuePair
{
Name = "MyCustomSetting",
Value = "MyCustomValue"
});
});
可以通过 SiteConfig.AppSettings 集合添加任何 App Service 应用程序设置。
为资源添加标签
标记有助于组织和管理Azure资源。 可以将标记添加到网站和 App Service 计划中。
将标记添加到网站:
builder.AddProject<Projects.aspire_starter_Web>("webfrontend")
.PublishAsAzureAppServiceWebsite((infra, website) =>
{
website.Tags.Add("Environment", "Production");
website.Tags.Add("Team", "Engineering");
});
将标签添加到应用服务计划中。
builder.AddAzureAppServiceEnvironment("app-service-env")
.ConfigureInfrastructure(infra =>
{
var plan = infra.GetProvisionableResources().OfType<AppServicePlan>().Single();
plan.Tags.Add("Environment", "Production");
plan.Tags.Add("CostCenter", "Engineering");
});
配置运行状况探测
运行状况探测允许Azure App Service监视应用程序的运行状况并做出路由决策。 可以使用该方法 WithHttpProbe 配置不同的探测类型。
#pragma warning disable ASPIREPROBES001
builder.AddProject<Projects.aspire_starter_Web>("webfrontend")
.WithHttpProbe(ProbeType.Liveness, "/healthz")
// ... other configuration
#pragma warning restore ASPIREPROBES001
注释
使用 WithHttpProbe 可能需要禁止 ASPIREPROBES001 显示诊断警告,因为此功能处于预览状态。
确保应用程序提供运行状况检查接口。 对于 ASP.NET Core应用,可以使用内置运行状况检查中间件:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddHealthChecks();
var app = builder.Build();
app.MapHealthChecks("/healthz");
app.Run();
配置外部终结点
将 Aspire 应用程序部署到 App Service 时,服务间通信需要外部 HTTP 端点。 与容器应用不同,App Service当前不通过内部终结点管理应用之间的流量。
var apiService = builder.AddProject<Projects.aspire_starter_ApiService>("apiservice")
.WithExternalHttpEndpoints()
.WithHttpHealthCheck("/health");
builder.AddProject<Projects.aspire_starter_Web>("webfrontend")
.WithExternalHttpEndpoints()
.WithReference(apiService)
.WaitFor(apiService);
WithExternalHttpEndpoints() 方法将项目配置为可通过公共 HTTP 终结点访问。 这是以下条件所必需的:
- Aspire 应用中其他服务需调用的后端服务
- 用户直接访问的前端应用程序