Jenkins將ASP.NETCore部署到Azure

来源:https://www.cnblogs.com/MindSharing/archive/2019/08/20/11382725.html
-Advertisement-
Play Games

首先需要獲得Azure上App-service 的porfile. 登錄portal 選到app,點擊Get publish pofile 將得到一個 ****.PublishSettings,註意這個文件還不是最後真正用於發佈的配置,還需要做如下操作,得到一個真正的發佈配置, 在VS 中打開項目, ...


首先需要獲得Azure上App-service 的porfile. 登錄portal 選到app,點擊Get publish pofile

 

將得到一個 ****.PublishSettings,註意這個文件還不是最後真正用於發佈的配置,還需要做如下操作,得到一個真正的發佈配置,

在VS 中打開項目,點擊發佈,導入配置

在導入配置後,在這個目錄下(項目web的路徑\Properties\PublishProfiles),能獲得真正的  pubxml 結尾的,配置文件

打開PublishSettings文件(註意不是pubxml )在裡面找到userPWD,複製密碼

測試這個文件是否能用,直接在CMD 裡面,Password  裡面填 剛纔複製的那個密碼

dotnet publish XX/XX.csproj /p:PublishProfile="XX.pubxml" /p:Password=XXX

正常情況就能發佈到azure 了,

簡單Jenkins 任務就使用一下代碼就行了

dotnet restore
dotnet build --configuration "Release"
dotnet publish XXX/xxxx.csproj /p:PublishProfile="xxxxxx- Web Deploy.pubxml" /p:Password=XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX

有幾個問題需要註意下:

1.使用 Jenkins 拉取代碼以後,需要把pubxml 複製到項目web的路徑\Properties\PublishProfiles 這路徑下麵,.net core 發佈不能指定配置文件位置,我也不清楚為什麼這麼死板,所以需要提前把配置文件 放到伺服器某個位置,讓Jenkins 可以複製

bat("copy /y \"${filePath}\" \"${destination}\"");

  

2.根據微軟Best practice,機密信息應該放到 KeyVault 裡面,而KeyVault 的名稱應該配置到app-servcie 的環境變數裡面,不應該通過appsetting.json來管理這個配置,萬一使用這個蠢做法,可以用下麵這個來改不同環境的配置

def void UpdateKeyVaultName(String prefix) {
    String appsettingJsonPath = "${env.WORKSPACE}\\XXXXXX\\appsettings.json";
	echo appsettingJsonPath;
	String keyVaultName = "${prefix}-XXXX";
	echo keyVaultName;
	withEnv(["VAR_KeyVault=$keyVaultName","VAR_JsonPath=$appsettingJsonPath"])
	{
		powershell '''
		$jsonPath = $env:VAR_JsonPath
		$appsettings = Get-Content $jsonPath | ConvertFrom-Json
		$appsettings.KeyVault = $env:VAR_KeyVault
		$appsettings | ConvertTo-Json | set-content $jsonPath
		'''
	}	
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 子類重新定義父類的某一個方法時,必須把父類的方法定義為virtual。 在定義介面中不能有方法體,虛方法可以。 實現時,子類可以不重新定義虛方法,但如果一個類繼承介面,那必須實現這個介面。 ...
  • 使用顏色標記的方式來控制Console的顏色輸出,讓Console顏色輸出不再繁瑣。 ...
  • 一 目標 推薦一款線上將Json對象轉換為Ts類的工具:https://apihelper.jccore.cn/jsontool 可以幫助前端開發人員提高開發效率。 二 背景 Json是一種輕量級的數據交換格式。易於人閱讀和編寫。同時也易於機器解析和生成。所以Json成為了前後端交互使用的主要格式。 ...
  • NET 特性(Attribute) 轉自 "博客園(Fish)" "特性(Attribute)" :是用於在運行時傳遞程式中各種元素(比如類、方法、結構、枚舉、組件等)的行為信息的聲明性標簽。 您可以通過使用特性向程式添加聲明性信息。一個聲明性標簽是通過放置在它所應用的元素前面的方括弧(\[ \]) ...
  • 1.多線程執行方法 2.線程調用 ...
  • 1.首先新建一個空的Asp.net core項目 2.新建一個類 gj.cs 3.添加資料庫上下文類。 4.添加控制器 5.視圖 F5運行程式 (如圖) ...
  • 1.泛形方法:具體實例點擊查看BuilderResultList 2.調用 ...
  • 1.僅適用於規則Excel:表頭和數據一一對應 2.涉及到Excel轉換為集合對象的部分代碼,完整npoi幫助類點擊查看 /// <summary> /// 預設把excel第一個sheet中的數據轉換為對象集合 /// </summary> /// <typeparam name="T"></ty ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...