使用 Azure DevOps Pipelines 生成 .NET Core WebJob 控制台应用 CI/CD

server/2024/9/23 3:13:24/

    Web 应用程序通常需要作为后台任务运行的进程,并在特定时间间隔进行计划或在事件中触发。它们不需要花哨的 IO 接口,因为重点是过程而不是输出。Azure WebJobs 提供了出色的支持,通常在云环境中通过 Web 控制台应用程序来实现此目的。WebJob 是 Azure 应用服务的一项功能,可用于在与 Web 应用、API 应用或移动应用相同的实例中运行程序或脚本。 Azure 应用服务是一种基于 HTTP 的服务,用于托管 Web 应用程序、REST API 和移动后端。

    .NET Framework 中的 Web 控制台应用可轻松使用 Azure 服务生成和部署 WebJobs。此外,可以使用 Azure DevOps Pipelines 轻松为 CI/CD 配置 WebJobs 控制台应用,以便在每次成功生成时自动将 Web 应用部署到 Azure 应用服务。因此,Azure 管道支持使用 Azure DevOps 服务以持续集成 (CI) /持续交付 (CD) 方式进行生成、测试和部署。

    如果在 .NET Framework 中生成 WebJob 控制台应用,则通过将父 API 或 Web 应用链接到 Web/API 应用,可以非常轻松地生成和部署 WebJob,如下所示:

846318f91cd7297e2f995b45886dabca.png

3b7b824097666c64b6a870fa0cd0b994.png

    .NET Core 中的设计不支持上述 WebJob 控制台应用程序与父 Web/API 应用的链接。那么我们该怎么做呢?

    在本文中,我们将了解如何独立于父 Web/API 应用生成 .NET Core WebJob 控制台应用,并使用 Azure DevOps 生成和发布管道将其部署在现有的父 Web/API 应用下。

生成管道:生成 .NET Core 控制台应用

若要生成 .NET Core 控制台应用,我们需要在 Azure DevOps 生成管道中执行四个基本生成任务。

  • dotnet restore

  • dotnet build

  • dotnet publish

  • 将生成项目发布到放置位置

Azure Web 作业仅支持以下文件类型:

  • .cmd、.bat、.exe

  • .ps1(使用 PowerShell.ps1 (using PowerShell)

  • .sh(使用 Bash)

  • .php(使用 PHP)

  • .py(使用 Python)

  • .js(使用Node.js)

  • .jar(使用 Java)

由于我们位于 .NET Core 中,因此我们期望有一个 .exe 文件作为控制台应用的输出。如果仅通过运行来生成 .NET Core 应用,它将生成一个 .DLL 文件,但不会生成.EXE文件。若要生成.EXE文件作为生成输出,请在步骤中使用以下参数:dotnet buildpublish

--configuration $(BuildConfiguration) --self-contained -r win10-x64 --output $(build.artifactstagingdirectory)

    这个参数在这里会有所不同,因为这将在构建中生成一个.EXE文件。--self-contained -r win10-x64

    接下来,选择该选项。这将从生成输出中创建一个 ZIP 文件。Enable Zip Published Projects

f0c30f9c8c21859d35ee959642671497.png

一旦它被发布到ZIP文件夹并完成,我们需要将此ZIP文件拖放到放置位置。用作要发布的路径。使用您选择的任何项目名称。在此示例中,项目名称为:$(Build.ArtifactStagingDirectory)webjobs_drop

5fc241b55d92e65d0bcfe8e701aa9b44.png

发布管道:将生成项目部署到 Azure 应用服务

运行生成管道后,你将在位置获取生成输出。webjobs_drop/.zip

若要将其部署到 Azure 应用服务中运行的任何现有 Web/API 应用的 WebJob,我们必须运行 Azure PowerShell 脚本任务来实现此目的。

我们将用于将生成输出部署到应用服务。这会将压缩的生成输出解压缩到文件夹中。KUDU Zip Deploy APIwwwroot\App_Data\Jobs\\ 

若要设置发布管道,我们需要使用以下管道变量创建一个空管道:

  • resourceGroupName- 应用程序的资源组名称

  • scheduleName- 有争议/触发(在本例中,它是连续的)

  • scmApiUrl- SCM API 网址;示例:https://.scm.azurewebsites.net/api

  • webJobName- 您的 WebJob 名称;您的代码将部署在 wwwroot\App_Data\Jobs\scheduleName\webJobName 文件夹下

  • zippedArtifactPath- 构建输出文件的压缩工件路径

28f7d116959675526c103d9f58c37cd7.png


946ec439b9ad7df81e84e2ef39db6339.png

设置变量后,我们需要执行以下操作:

  • 添加一个Azure PowerShell script task

  • 选择“Azure 连接”类型

  • 选择 WebApp 所在的 Azure 订阅

  • 选择“脚本类型”作为内联脚本

71c6200c397858bc85042e49a1708868.png

在内联脚本编辑器中,添加以下 PowerShell 脚本:

#Zipped artifact path - get the path from Azure DevOps Pipeline variables
$path = "$(System.DefaultWorkingDirectory)\$($env:zippedArtifactPath)"#Test the path if exists
if (-not (Test-Path $path)) 
{throw [System.IO.FileNotFoundException] "$($path) not found."
}#Resource type and details
$resourceType = "Microsoft.Web/sites/config"
$resourceName = "$($env:webAppName)/publishingcredentials"#Get the Publishing Profile details
$publishingCredentials = Invoke-AzureRmResourceAction -ResourceGroupName $($env:resourceGroupName) -ResourceType $resourceType -ResourceName $resourceName -Action list -Force#Creating the Auth Token using user name and password from Publish profile credentials
$base64AuthInfo = [Convert]::ToBase64String([Text.Encoding]::ASCII.GetBytes(("{0}:{1}" -f $publishingCredentials.Properties.PublishingUserName,$publishingCredentials.Properties.PublishingPassword)))#Get the file from the Build Artifacts path 
$files = Get-ChildItem -Path $path -Recurse
Test-Path -Path $files[0]   #Authentication Header
$authHeader = " Basic " + $base64AuthInfo#Kudu Zip Deploy API URL
$deployUrl = "$($env:scmApiUrl)/zip/site/wwwroot/App_Data/jobs/$($env:scheduleName)/$($env:webJobName)/"#Invoke Kudu Zip Deploy API to deploy the WebJob
$contentType = "multipart/form-data"
$userAgent = "powershell/1.0"
$ZipHeaders = @{
Authorization = $authHeader
}$response = Invoke-RestMethod -Uri  ([System.Uri]::new($deployUrl)) -Headers $ZipHeaders  -UserAgent $userAgent -Method PUT -InFile $files[0] -ContentType $contentTypeWrite-Host "Deployment Successful"

此 PowerShell 脚本将获取 Web 应用的发布配置文件详细信息,并使用此信息登录到 KUDU ZipDeploy API,以将 Zipped 生成输出上传到所需位置。

部署位置定义如下:

  • SCM API URL 和虚拟目录路径 https://<>.scm.azurewebsites.net/api/zip 
    site/wwwroot/App_Data/jobs/<continuous/triggered>/

访问特定于环境的配置

上述生成和发布管道将为 .NET Core 控制台应用程序生成并生成.EXE文件,并将生成输出部署到 Azure 应用服务虚拟目录。在某些情况下,Web 作业可能需要读取某些特定于环境的配置。在这种情况下,您必须将特定于环境的文件添加为 .appsettings.jsonappsettings.json

要从特定于环境的 JSON 文件中读取值,我们可以依赖该变量。可以从 Azure 门户手动设置此变量,也可以在应用设置部分使用 Azure 发布管道部署父 WebApp/API 应用时设置此变量。ASPNETCORE_ENVIRONMENT

builder.ConfigureAppConfiguration((hostingContext, config) =>{var environmentName = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT");Console.WriteLine("Environment Variable: " + environmentName);var env = hostingContext.HostingEnvironment;Console.WriteLine("hostingContext.HostingEnvironment: " + env.EnvironmentName);config.SetBasePath(Directory.GetCurrentDirectory()).AddJsonFile($"appsettings.json", optional: true, reloadOnChange: true).AddJsonFile($"appsettings.{environmentName}.json", optional: true, reloadOnChange: true).AddEnvironmentVariables().Build();});

将上述代码添加到文件中,以便从文件中读取特定于环境的值。Program.csappsettings.json

总而言之,我们执行了以下操作:

  • dotnet publishwith 参数,用于生成 WebJob 支持的 EXE 文件--self-contained -r win10-x64 

  • 压缩生成项目目录

  • 使用 API 将 WebJob 控制台应用程序发布到现有的 web/API 应用程序虚拟目录。KUDU ZipDeployAzure PowerShell Script


http://www.ppmy.cn/server/59936.html

相关文章

Java面试题:三个线程交替打印ABC如何实现?

目录 方法一&#xff1a;使用synchronized和wait/notify方法二&#xff1a;使用CompletableFuture实现 方法一&#xff1a;使用synchronized和wait/notify package com.demo;import java.util.concurrent.CompletableFuture;public class PrintABC {// 当前状态private static…

【matlab】周期性信号分析

目录 信号预处理 周期性特征提取方法 频谱分析 傅里叶变换 快速傅里叶变换&#xff08;FFT&#xff09; 周期图法 Welch法 自相关分析 时频分析 基于模型的方法 时间序列分解 应用实例 提取信号的周期性特征是一个在信号处理领域广泛应用的技术&#xff0c;特别是在…

ThreeJS-3D教学十五:ShaderMaterial(noise、random)

ThreeJS-3D教学十四:ShaderMaterial(length、fract、step) 上面这篇主要是操作 fragmentShader 片元着色器,实现对物体颜色的修改,这次咱们来看下修改 vertexShader 顶点着色器,这个其实就是位移各个顶点的位置。 接下来我们先介绍下 noise 噪声函数(Perlin Noise、Sim…

Java面试题系列 - 第10天

题目&#xff1a;Java中的枚举类型&#xff08;enum&#xff09;及其高级应用 背景说明&#xff1a;Java中的枚举类型&#xff08;enum&#xff09;是一种特殊的类&#xff0c;用于定义一组固定的常量。枚举类型不仅限于提供常量集合&#xff0c;还可以实现接口、拥有方法和构…

昇思25天学习打卡营第19天|应用实践之基于MobileNetv2的垃圾分类

基本介绍 今天的应用实践是垃圾分类代码开发&#xff0c;整体流程是读取本地图像数据作为输入&#xff0c;对图像中的垃圾物体进行检测&#xff0c;并且将检测结果图片保存到文件中。采用的是MobileNetv2模型&#xff0c;使用官方提供的数据集&#xff0c;数据集分为4大类&…

设计模式:从HttpServletRequestWrapper了解装饰者模式

从一个参数处理的问题开始 为了满足安全测试&#xff0c;需要给系统追加防XSS注入的功能&#xff0c;关于此类安全的问题&#xff0c;一般的解决方案就是在请求到达Controller之前&#xff0c;使用Web框架的Filter或者Spring本身的拦截器对HttpServletRequest对象的参数进行处…

星环科技推出语料开发工具TCS,重塑语料管理与应用新纪元

5月30-31日&#xff0c;2024向星力未来数据技术峰会期间&#xff0c;星环科技推出一款创新的语料开发工具——星环语料开发工具TCS&#xff08;Transwarp Corpus Studio&#xff09;&#xff0c;旨在通过全面的语料生命周期管理&#xff0c;极大提升语料开发效率&#xff0c;助…

FastAPI 学习之路(四十八)WebSockets(四)接口测试

在我们测试的过程中&#xff0c;肯定会对接口进行测试。之前分享过的FastApi学习之路&#xff08;三十八&#xff09;对开发接口进行测试&#xff0c;那么我们针对websockets接口怎么测试呢。 其实也很简单 from fastapi.testclient import TestClient from main import appd…