在Azure App Service
中咱们能够经过独立部署进行部署咱们的.NET5应用程序,由于它不会依赖目标系统上的环境,而且全部组件(包括librarys和运行时)都与该应用程序一块儿使用,而且与其余应用程序进行隔离,这样其实咱们更好的去控制应用程序运行的版本。json
一、选择要发布的项目,鼠标右键单击项目,而后选择发布,会出现以下内容:api
二、接下来咱们能够选择Linux应用服务或Windows应用服务app
三、最后咱们点击完成后选择部署模式此处选择独立模式框架
接下来咱们发布应用程序便可ui
目前在Azure App Service
中并无为咱们提供默认的.net5运行时环境,那么咱们如何以框架依赖的形式使用.net5呢?看以下步骤this
一、点击左侧的扩展
操作系统
二、选择.NET5运行时,以下图所示.net
这样咱们就完成了咱们框架依赖的配置,也不能说配置,能够说是这样咱们就已经完成了在咱们App Service中安装了.net5
的环境,因此咱们能够去使用框架依赖的形式去发布咱们的代码。debug
运行.NET 5应用程序的另外一种方法是将Docker容器部署到Linux或Windows上的App Service(仅Premium SKU)。部署容器时,咱们会将应用程序及其依赖项打包到基于Linux或Windows的映像中,以在App Service平台上运行。这使咱们的应用程序本质上更具可移植性,由于它不依赖于主机操做系统,而且在映像中添加了运行时和SDK。rest
一旦为.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>