【Azure DevOps系列】Azure DevOps构建并发布.NET5应用程序
Azure App Service
独立部署
在Azure App Service
中我们可以通过独立部署进行部署我们的.NET5应用程序,因为它不会依赖目标系统上的环境,并且所有组件(包括librarys和运行时)都与该应用程序一起使用,并且与其他应用程序进行隔离,这样其实我们更好的去控制应用程序运行的版本。
1、选择要发布的项目,鼠标右键单击项目,然后选择发布,会出现如下内容:
2、接下来我们可以选择Linux应用服务或Windows应用服务
3、最后我们点击完成后选择部署模式此处选择独立模式
接下来我们发布应用程序即可
框架依赖
目前在Azure App Service
中并没有为我们提供默认的.net5运行时环境,那么我们如何以框架依赖的形式使用.net5呢?看如下步骤
1、点击左侧的扩展
2、选择.NET5运行时,如下图所示
这样我们就完成了我们框架依赖的配置,也不能说配置,可以说是这样我们就已经完成了在我们App Service中安装了.net5
的环境,所以我们可以去使用框架依赖的形式去发布我们的代码。
容器部署
运行.NET 5应用程序的另一种方法是将Docker容器部署到Linux或Windows上的App Service(仅Premium SKU)。部署容器时,我们会将应用程序及其依赖项打包到基于Linux或Windows的映像中,以在App Service平台上运行。这使我们的应用程序本质上更具可移植性,因为它不依赖于主机操作系统,并且在映像中添加了运行时和SDK。
一旦为.NET 5设置了应用程序,部署容器化应用程序的步骤将与任何其他容器部署相同。 右键单击我们的项目,然后单击添加-> Docker支持。我们的.NET Core项目将添加一个新的Dockerfile,其中包含.NET 5.0基本映像和SDK,供我们发布。
#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.
FROM mcr.microsoft.com/dotnet/core/aspnet:5.0-buster-slim AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443
FROM mcr.microsoft.com/dotnet/core/sdk:5.0-buster AS build
WORKDIR /src
COPY ["src/TinyBlog.Hosts.Web.Server/NuGet.config","src/TinyBlog.Hosts.Web.Server/"]
COPY ["src/TinyBlog.Hosts.Web.Server/TinyBlog.Hosts.Web.Server.csproj", "src/TinyBlog.Hosts.Web.Server/"]
COPY ["src/TinyBlog.Hosts.Web.Client/TinyBlog.Hosts.Web.Client.csproj", "src/TinyBlog.Hosts.Web.Client/"]
RUN dotnet restore "src/TinyBlog.Hosts.Web.Server/TinyBlog.Hosts.Web.Server.csproj" --configfile "src/TinyBlog.Hosts.Web.Server/NuGet.config"
COPY . .
WORKDIR "/src/src/TinyBlog.Hosts.Web.Server"
RUN dotnet build "TinyBlog.Hosts.Web.Server.csproj" -c Release -o /app/build
FROM build AS publish
RUN dotnet publish "TinyBlog.Hosts.Web.Server.csproj" -c Release -o /app/publish
FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "TinyBlog.Hosts.Web.Server.dll"]
另外要注意的是对Nuget仓库的使用,我们需要进行配置一下将其在nuget包还原的时候还能在仓库中获取到我们所需要的包,NuGet.config
如下所示:
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<packageSources>
<clear />
<!--Begin: Package sources managed by Dependency Flow automation. Do not edit the sources below.-->
<add key="darc-pub-dotnet-blazor-cc44960" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/darc-pub-dotnet-blazor-cc449601/nuget/v3/index.json" />
<!--End: Package sources managed by Dependency Flow automation. Do not edit the sources above.-->
<add key="dotnet-eng" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet-eng/nuget/v3/index.json" />
<add key="dotnet-tools" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet-tools/nuget/v3/index.json" />
<add key="dotnet5" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet5/nuget/v3/index.json" />
<add key="dotnet5-transport" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet5-transport/nuget/v3/index.json" />
<add key="roslyn" value="https://dotnet.myget.org/F/roslyn/api/v3/index.json" />
<add key="nuget.org" value="https://api.nuget.org/v3/index.json" />
<add key="roslyn-tools" value="https://dotnet.myget.org/F/roslyn-tools/api/v3/index.json" />
<!-- Used for the SiteExtension 3.1 bits that are included in the 5.0 build -->
<add key="dotnet31-transport" value="https://pkgs.dev.azure.com/dnceng/public/_packaging/dotnet3.1-transport/nuget/v3/index.json" />
</packageSources>
</configuration>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构