技术速递|将 .NET Aspire 添加到您现有的 .NET 应用程序中

news/2024/9/23 14:57:33/

作者:Jon Galloway
排版:Alan Wang

.NET Aspire 是一个针对 .NET 的新型云就绪堆栈,可帮助开发人员快速轻松地开发分布式应用程序。您可能已经看过一些演示,展示了大型 .NET 解决方案,其中充满了复杂的云依赖项,比如 Redis、Kafka 和 Postgres,也许您会想:这些技术也许有一天会用到,但对于我当前的项目来说,并没有太多的实际用途。

但 .NET Aspire 不仅仅涉及尖端技术和新兴应用程序;它还可以让您当前的应用更加简单。使用 .NET Aspire,您可以简化启动过程、改进监控并提高应用程序的可靠性。此外,您可以使用服务发现来增强您的应用程序,即使您尚未准备好使用更复杂的功能或服务(如 Redis 或容器化部署)。

在这篇文章中,我们将介绍如何轻松地改进现有解决方案 - 只需更轻松地维护和添加您已经在使用的功能。当然,您可以更轻松地集成更复杂的云依赖项和功能,这很好……但即使您从未这样做过,这仍然是一种胜利。

TLDR:在不到 5 分钟的时间内,您可以将 .NET Aspire 添加到您现有的应用程序中并获得仪表板、运行状况检查等…所有这些都无需改变您的应用程序的工作方式、CI/CD 管道或部署过程。

什么是 .NET Aspire?

如果您问五个人,您很可能会得到五个不同的答案。老实说,这有点难以描述,尝试简短地描述可能会变成一些流行语宾果游戏。实际上,这只是解决问题的一种方法:构建分布式应用程序很难。即使只是运行应用程序也需要启动一个或多个服务和前端,并确保它们可以相互通信,这可能会令人沮丧。如果这更容易,那不是很好吗?这就是 .NET Aspire 的目标,成为分布式应用程序的构建块,使它们更易于观察、更具弹性、更可扩展和更易于管理。

让我们来看看许多应用程序是如何随着时间的推移而演变的。很多应用程序都是从单一的整体概念验证开始的。您有一个带有数据库的应用程序。
在这里插入图片描述
假设您的概念验证成功,那么除了数据库之外,几乎每个现代应用程序都会发展到至少包含一个前端和一个后端。
在这里插入图片描述
然后,也许,如果我们的应用程序的使用和功能随着时间的推移不断增长,应用程序将变得真正分布式,依赖于大量的分布式依赖项。
在这里插入图片描述
但重点是!即使在非常简单的概念验证阶段,当然在前端-后端-数据库阶段,我们也可以从 .NET Aspire 中受益!只需几行代码,无需弄乱我们的 CI 或部署,我们就可以真正简化我们的日常开发人员体验。

第 1 步:使用 ServiceDefaults 启用因我们太忙而没有启用的 .NET 功能

多年来,ASP.NET Core 团队一直在开发一些很酷的功能,比如跟踪、运行状况检查和弹性。我已经做了多次关于“一小时 ASP.NET 改造”的会议演讲,我们只需打开并配置多年来一直存在的所有这些酷炫功能即可。但问题是……在阅读文档并练习之后,做这个演讲需要一个小时!如果我只是拨动一下“启用专业模式”开关会怎么样?

这就是 Service Defaults 为您做的事情。您只需打开 Service Defaults,即可获得智能日志记录、运行状况检查、弹性等功能,这些都基于 .NET 团队针对 ASP.NET Core 应用和服务的建议。如果您愿意,您可以轻松编辑 ServiceDefaults 项目中的 Program.cs 文件,但您不必这样做。只需将其打开即可。

添加 ServiceDefaults 项目

让我们看一个简单的前端 - 后端应用程序的示例。我将使用 Jeff Fritz 在 Let’s Learn .NET Aspire 活动系列中提供的新 MyWeatherHub 示例,从 start-with-api 代码开始。

打开解决方案,我们将看到有两个项目:

  • MyWeatherHub – 一个显示实时天气数据的 Web 前端项目
  • API – 一个最小 API 项目,通过一组 HTTP API 端点公开来自美国国家气象局的实时天气数据

让我们将 Service Defaults 添加到这个解决方案中,以便我们可以在前端和后端同时获得运行状况检查、日志记录和其他推荐的功能。

在安装了 C# Dev Kit 的 Visual Studio 2022 或 Visual Studio Code 中,我们需要执行以下操作:

  1. 右键单击解决方案并选择 Add > New Project。

  2. 选择 .NET Aspire Service Defaults 项目模板。

  3. 将项目命名为 ServiceDefaults(如果您有创意,任何名称都可以,但本文中的说明假设您使用 ServiceDefaults)。

  4. 单击 Next > Create。

在 Visual Studio 2022 中的外观如下:
在这里插入图片描述
在 Visual Studio Code 中,它如下所示:
在这里插入图片描述
您还可以使用以下命令从命令行添加服务默认值:

dotnet new aspire-servicedefaults -n ServiceDefaults

以上所有选项都只是将一个新项目放入您的解决方案中,该项目了解大多数 ASP.NET Core 分布式应用程序的最佳设置。但是,您现有的应用程序尚未使用它。接下来我们将连接它。

配置 ServiceDefaults

在 Api 和 MyWeatherHub 项目中添加对 ServiceDefaults 项目的引用:

  1. 右键单击 Api 项目并选择 Add > Reference。

  2. 检查 ServiceDefaults 项目并单击 OK。

  3. 右键单击 MyWeatherHub 项目并选择 Add > Reference。

  4. 检查 ServiceDefaults 项目并单击 OK。

Visual Studio 2022 提示
在 Visual Studio 2022 中,您可以将项目拖放到另一个项目上以添加引用。

  1. 在 Api 和 MyWeatherHub 项目中,更新它们的 Program.cs 文件,在 var builder = WebApplication.CreateBuilder(args); 行后立即添加以下行:
builder.AddServiceDefaults();
  1. 在 Api 和 MyWeatherHub 项目中,更新它们的 Program.cs 文件,在 var app = builder.Build(); 行后立即添加以下行:
app.MapDefaultEndpoints();

运行应用程序

首先,我们将使用多项目启动配置来启动应用程序。这很好,这是我们多年来一直采用的做法,但我不得不承认,我并不喜欢这种方式。请记住,我们将在下一步中简化此操作。我们将分两步进行,以明确服务默认值中发生了什么以及 AppHost 添加了哪些部分。

如果您使用的是 Visual Studio 2022,请右键单击 MyWeatherHub 解决方案并转到属性。选择 Api 和 MyWeatherHub 作为启动项目,然后选择 OK。
在这里插入图片描述
现在单击“Start”以启动并调试两个项目。

如果您使用的是 Visual Studio Code,请使用“运行和调试”面板运行 Api 和 MyWeatherHub 项目。示例项目已包含一个 launch.json 文件,其中包含运行这两个项目所需的配置。

测试 Service Defaults 更改

  1. 通过导航到以下 URL 来测试应用程序:
  • https://localhost:7032/swagger/index.html – API

  • https://localhost:7274/ – MyWeatherHub

  1. 您应该看到 API 的 Swagger UI 和 MyWeatherHub 主页。

  2. 您还可以通过导航到 https://localhost:7032/health 查看 API 的运行状况检查。

  3. 您还可以通过导航至 https://localhost:7274/health 查看 MyWeatherHub 的运行状况检查。

  4. 查看终端中的日志以查看运行状况检查和其他遥测数据(例如 Polly 的弹性):

Polly: Information: Execution attempt. Source: '-standard//Standard-Retry', Operation Key: '', Result: '200', Handled: 'False', Attempt: '0', Execution Time: '13.0649'
  1. 点击 5 个不同的城市,将抛出“随机”错误。您将看到 Polly 重试策略的实际作用。
Polly: Warning: Execution attempt. Source: '-standard//Standard-Retry', Operation Key: '', Result: '500', Handled: 'True', Attempt: '0', Execution Time: '9732.8258'
Polly: Warning: Resilience event occurred. EventName: 'OnRetry', Source: '-standard//Standard-Retry', Operation Key: '', Result: '500'
System.Net.Http.HttpClient.NwsManager.ClientHandler: Information: Sending HTTP request GET http://localhost:5271/forecast/AKZ318

一切正常……每个应用程序的输出都会在单独的控制台窗口中弹出,我们可以在终端中看到运行状况检查和日志。因此,我们打开了所有这些功能真是太好了,但管理所有这些 URL、浏览器选项卡和控制台窗口有点麻烦。您最终会在它们之间按 Alt-Tab 键,这是一种非常脱节的体验。
在这里插入图片描述
Service Defaults 在单个项目级别上运行得很好,但它无法帮助我们管理解决方案中的多个项目。这就是 AppHost 的作用所在。

第 2 步:使用 AppHost 简化启动并添加精美的仪表板

好吧,这很酷!我们在解决方案中添加了一个项目和两行代码,并获得了运行状况检查、日志记录、弹性等等。

但我们可以通过添加 AppHost 来让它变得更好。这种多项目配置功能是可行的,但是当我们向解决方案中添加其他项目时,设置和更新会有点麻烦。一旦我们开始运行,我们就必须浏览一系列具有不同端口的 URL,并分别管理每个项目。例如,如果我们想查看日志或输出,我们必须检查每个项目的控制台窗口。随着我们向解决方案添加更多 API 和服务,情况会变得更糟——需要管理更多的 URL、需要检查更多的控制台窗口等。我们可能在生产中设置了一些花哨的仪表板和监控,但这对我的开发没有帮助。

AppHost 有很多很棒的功能,但我最喜欢的两个是针对上述问题的解决方案:它简化了项目启动,并添加了一个很棒的仪表板来监控和管理我开发环境中的应用程序。了解其作用的最好方法是将其添加到我们的解决方案中。

添加 AppHost 项目

这是我们之前使用 ServiceDefaults 执行的标准“添加项目”步骤,但这次我们将选择“.NET Aspire App Host”作为项目模板。在 Visual Studio 2022 或安装了 C# DevKit 的 Visual Studio Code 中:

  1. 右键单击解决方案并选择 Add > New Project。

  2. 选择 .NET Aspire App Host 项目模板。

  3. 将项目命名为 AppHost(同样,任何名称都可以)。

  4. 单击 Next > Create。

在这里插入图片描述
在这里插入图片描述
从命令行,您可以执行以下操作:

dotnet new aspire-apphost -n AppHost

就像我们添加 Service Defaults, 时一样,我们需要添加项目引用和几行代码来使 AppHost 工作。

添加项目引用

在新的 AppHost 项目中添加对 Api 和 MyWeatherHub 项目的引用:

  1. 右键单击 AppHost 项目并选择 Add > Reference。

  2. 选中 Api 和 MyWeatherHub 项目并单击OK。

注意:如果您记得之前的提示,可以将项目拖放到另一个项目上以添加引用。

添加这些引用时,源生成器会自动生成引用 App Host 中的项目所需的代码。

编排应用程序

在 AppHost 项目中,更新 Program.cs 文件,在 var builder = DistributedApplication.CreateBuilder(args); 行后立即添加以下行:

var api = builder.AddProject<Projects.Api>("api");
var web = builder.AddProject<Projects.MyWeatherHub>("myweatherhub");

用最简单的方式运行应用程序!

之前,我们设置了一个多项目启动配置文件。这仍然有效,但从现在开始,您不必为此烦恼。而是将 AppHost 项目设置为启动项目。它了解所有其他项目,并会自动启动它们。这意味着,如果您在开始时添加 AppHost(或使用 .NET Aspire Starter Application 模板或 .NET Aspire Application 模板),则不再需要设置多项目启动配置文件。更好的是,如果您向解决方案添加更多服务,AppHost 也会自动选择它们。

在 Visual Studio 中,您可以通过右键单击 AppHost,然后单击“设置默认项目”并单击“启动”,将 AppHost 项目设置为 Visual Studio 中的启动项目。

如果您使用的是 Visual Studio Code,请将 launch.json 文件的内容替换为以下内容,然后在运行和调试面板中点击运行。

{"version": "0.2.0","configurations": [{"name": "Run AppHost","type": "dotnet","request": "launch","projectPath": "${workspaceFolder}\\AppHost\\AppHost.csproj"}]}

嘿,我们有一个仪表板!

还记得我们必须浏览一系列不同的 URL 才能查看我们的应用及其运行状况检查吗?现在,AppHost 将自动启动一个包含我们所有服务及其依赖项的仪表板。它将所有运行状况检查、跟踪、日志和环境变量等信息汇总到一个地方。而且,如果我们向解决方案添加更多服务,它们将自动显示在仪表板中。让我们来看看。
在这里插入图片描述
首先,让我们看一下资源。这是我们解决方案中所有资源的便捷列表。我们可以看到 API 和 MyWeatherHub 项目,并在启动时观察它们的状态。我们还可以点击链接访问它们的端点、日志和跟踪信息。

我们之前添加的 ServiceDefaults 项目会自动为我们的所有项目配置跟踪。我们可以在 Traces 选项卡中看到这一点。这是了解应用程序中的时间和依赖关系的好方法。
在这里插入图片描述
Metrics 选项卡向我们展示了有关应用程序的大量信息,包括 CPU 和内存使用情况以及请求和错误的数量。同样,这些都是由 ServiceDefaults 项目自动为我们设置的,并在 AppHost 仪表板中显示。
在这里插入图片描述
Structured 选项卡展示了我们应用中的所有结构化日志。这是查看应用程序中错误和其他重要信息的好方法。
在这里插入图片描述

总结

重点是,.NET Aspire 不仅适用于新应用程序或大型企业解决方案。它现在也适合您,它可以让您现有的应用程序变得更好。您可以将其添加到现有解决方案中,只需几行代码即可获得很多好处。而且,如果您还没有准备好使用更高级的功能,如服务发现或容器化部署,那也没关系。您仍然可以从 .NET Aspire 为您的应用程序带来的简单性和可靠性中受益。


http://www.ppmy.cn/news/1512602.html

相关文章

SAP Parallel Accounting(平行分类账业务)配置及操作手册【适用于多国家会计准则】

1. 配置准备 1.1 理解平行账概念 平行账&#xff0c;也称为多分类账&#xff0c;是SAP系统中的一项功能&#xff0c;它允许企业按照不同的会计准则来维护各自的财务数据。这种设置特别适用于那些需要符合多种会计准则的跨国公司。通过平行账&#xff0c;企业可以在不同的分类…

继电器介绍及qt操作继电器实战

一.继电器基础介绍 32路继电器通常用于自动化控制系统中&#xff0c;能够同时控制多达32个不同的电气设备。以下是对32路继电器的一些详细介绍&#xff1a; 1. 基本概念 继电器&#xff1a;一种电气控制装置&#xff0c;当输入信号&#xff08;通常是电流或电压&#xff09;…

goweb框架-gin

文章目录 Gin框架概览Gin框架的特点Gin框架的安装和基本使用安装基本使用 路由系统路由的基本概念Gin框架路由的特点 Radix Tree&#xff08;基数树&#xff09;基数树的定义和原理基数树在Gin框架中的应用节省空间的优化动态路由和通配符处理 路由树的构建注册路由的过程路由树…

杭汽莅临天洑软件,共启综合智慧能源项目新篇章

在绿色低碳转型的时代浪潮中&#xff0c;杭汽轮新能源公司与南京天洑软件有限公司携手并进&#xff0c;在天洑软件总部隆重举行了综合智慧能源项目的启动会。 启动会上&#xff0c;杭汽高层领导吕紫瑞及核心团队成员、天洑软件董事长张明及项目团队骨干成员齐聚一堂&#xff0c…

信息竞赛2024年第三次csp-j模拟测试赛后总结

目录 一.第一题&#xff1a;孤独的数列 (lonely) 二.第二题&#xff1a;五颜六色 (color) 三.第三题&#xff1a;获取字符串 (obtain) 首先自我反思&#xff0c;因为打错了freopen导致爆零&#xff0c;这是重大的失误&#xff0c;以后绝对不能再犯。 一.第一题&#xff1a;…

EmguCV学习笔记 VB.Net 4.5 像素距离和连通区域

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 教程VB.net版本请访问&#xff1a;EmguCV学习笔记 VB.Net 目录-CSDN博客 教程C#版本请访问&#xff1a;EmguCV学习笔记 C# 目录-CSD…

TypeScript学习笔记2---ts的函数定义详解

前言&#xff1a; TS中函数定义和JS是一模一样的&#xff0c;可以是普通函数申明&#xff0c;也可以函数表达式 但是在TS中针对函数做了很多的约束、函数的参数进行约束、函数的返回值进行了约束 一、函数的参数 在函数形参进行了约束&#xff0c;在传递值的时候&#xff0…

django之bulk_create

在 Django 中&#xff0c;批量创建对象可以显著提高性能&#xff0c;特别是在需要创建大量对象时。Django 提供了 bulk_create 方法来实现这一点。 假设的模型 首先&#xff0c;假设有一个简单的模型 Book&#xff0c;包含书名和作者字段。 # models.py from django.db impo…