Jenkins編譯.NET?Core、.NET?Framework項(xiàng)目并遠(yuǎn)程部署到IIS
Windows
我們先在 Windows 上安裝好相應(yīng)的環(huán)境。
Jenkins 依賴于 JDK 11,請自行查找方法安裝。
在 https://www.jenkins.io/download/ 中可以下載到 Windows Jenkins 版本的安裝包,下載完畢后,直接安裝即可,安裝完成后會自動啟動。
Jenkins 的安裝目錄默認(rèn)為:C:\Windows\System32\config\systemprofile\AppData\Local\Jenkins.jenkins,密碼/密鑰一般在其目錄下的 secret-file
文件。
安裝 Jenkins 后,打開 8080
端口訪問 Jenkins,然后根據(jù) Linux下使用Jenkins自動化構(gòu)建.NET Core應(yīng)用_安裝插件 一節(jié),把插件安裝好,再額外安裝一個 powershell
插件。
安裝 Git
接著,在 Windows 服務(wù)器中,將 Git 安裝好,一般 Git 的安裝目錄為 C:\Program Files\Git
。
然后添加下面兩個 Git 相關(guān)的目錄到系統(tǒng)環(huán)境變量中。
C:\Program Files\Git\cmd C:\Program Files\Git\usr\bin
如不配置 C:\Program Files\Git\usr\bin 到環(huán)境變量,會出現(xiàn) nohup 錯誤,Jenkins 依賴 nohup 命令。
WebDeploy
WebDeploy 是一個 IIS 遠(yuǎn)程部署工具,通過 WebDeploy 我們可以很方便地打包應(yīng)用遠(yuǎn)程部署到 IIS 中,而不需要手動重啟、更替網(wǎng)站文件、重啟程序池等。WebDeploy 下載地址:https://www.microsoft.com/zh-cn/download/details.aspx?id=43717
安裝完成后,其程序默認(rèn)安裝目錄為:
C:\Program Files\IIS\Microsoft Web Deploy V3
請?zhí)砑哟四夸浀较到y(tǒng)環(huán)境變量中。
同時,在要被遠(yuǎn)程部署的服務(wù)器中,也安裝 WebDeploy。
Windows 從節(jié)點(diǎn)
如果你有一臺 Jenkins Master 服務(wù)器,然后再添加 Windows Jenkins Node,做主從 Jenkins,那么可以按照下面的方法將 Windows 加入到 Linux 節(jié)點(diǎn)中。
如果你只部署 Windows ,那么 Windows 上的的 Jenkins 就是 Master,可以跳過此步。
打開 Master Jenkins 的 Web 界面,在左側(cè)菜單導(dǎo)航中打開 Manage Jenkins
,然后在 System Configuration
中,選擇 Manage Nodes and Clouds
。
然后添加新的節(jié)點(diǎn) “New Node”。
節(jié)點(diǎn)名稱可隨意,在接下來要求填寫的 Label 中,需要填寫 “windows” ,當(dāng)然填寫其它標(biāo)識也行,但是一般 Label 用來標(biāo)識系統(tǒng)特性的,另外也會要求填寫構(gòu)建目錄,這是用于存放 Jenkins 工作時的文件,例如拉取代碼、執(zhí)行命令等,都會在這個目錄下操作。
點(diǎn)擊藍(lán)色字體的 agent.jar
,可以下載 java 包。
將 agent.jar 包放到 Jenkins 所在的 Windows 中,然后按照提示的命令,啟動 agent.jar。
就是把 agent.jar 放到目錄中,然后打開 powershell 或者 cmd,復(fù)制上面的
Java -jar agent.jar -jnlpUrl .....
命令,直接執(zhí)行就行。
接著,在 Jenkins 界面,可以看到另一臺 Windows 從節(jié)點(diǎn)已經(jīng)加了上去。
.NET Core
這一小節(jié),介紹如何構(gòu)建、遠(yuǎn)程部署 .NET Core 應(yīng)用到 IIS 中。
對于 .NET Core 應(yīng)用,其過程比較簡單,只需要安裝 .NET Core SDK 即可,無需再額外操作。
.NET Core 各類版本下載地址:
https://dotnet.microsoft.com/download/dotnet
.NET Core 3.1 版本下載地址:
處理 IIS
在你要部署應(yīng)用的那臺 Windows 服務(wù)器 上,打開 IIS ,點(diǎn)擊 ”應(yīng)用程序池“,然后添加一個新的。
接著,添加一個網(wǎng)站。
然后開始添加一個新用戶,點(diǎn)擊主機(jī)名稱,然后點(diǎn)擊 “IIS 管理器用戶”,然后添加一個用戶。
然后為網(wǎng)站啟用 WebDeploy 部署。
處理項(xiàng)目 Jenkinsfile
筆者已經(jīng)上傳了 Demo 項(xiàng)目已經(jīng) Jenkinsfile 文件,讀者直接 fork 項(xiàng)目即可,示例項(xiàng)目在 coreiis 分支中。
https://github.com/whuanle/DotNetCoreJenkinsDemo/tree/coreiis
然后,下載源碼,修改一下 Jenkinsfile 文件。
// IIS 配置,遠(yuǎn)程發(fā)布的變量 IISTMP = 'C:/webdemo_tmp' // 用于打包發(fā)布的臨時目錄 IISAPP = 'jenkinsdemo.com' // 網(wǎng)站名稱 IISADDR = 'https://192.168.0.66:8172/msdeploy.axd' // WebDeploy 的地址 IISUSER = 'jenkinesdemo' // 用于登錄到 IIS 的賬號密碼 IISADMIN = 'jenkinesdemo'
按照筆者的 demo,讀者只需要修改一下 IISADDR 中的 IP 和 用戶名或密碼即可。
接著,使用 Jenkins ,添加流水線部署即可。這里不再贅述 Jenkins 上的新建流程,讀者可以參考筆者的另一篇文章:
Linux下使用Jenkins自動化構(gòu)建.NET Core應(yīng)用_構(gòu)建流水線
.NET Framework
為了能夠編譯 .NET Framework 應(yīng)用,我們需要搭建起 .NET Framework 應(yīng)用的編譯環(huán)境,由于 .NET Framework 嚴(yán)重依賴 Vistual Studio,如果脫離 VS 環(huán)境,則需要安裝很多環(huán)境工具,才能使用命令編譯程序,比較麻煩,讀者需要耐心處理。
示例項(xiàng)目筆者已經(jīng)上傳到 https://github.com/whuanle/DotNetCoreJenkinsDemo/tree/fxiis 中。
安裝環(huán)境
.NET Framework SDK
.NET Framework 包提供編譯、運(yùn)行 .NET 程序的環(huán)境。
安裝 .NET Framework 框架,其版本不定,按照要編譯的項(xiàng)目其需要的版本為準(zhǔn),可安裝多個版本。
例如 .NET Framework 4.6.1 和 .NET Framework 4.6.1 Developer Pack 。
下載地址:https://dotnet.microsoft.com/download/dotnet-framework
MSBuild
MSBuild 是一個 .NET 程序的編譯工具,可以在脫離 VS 環(huán)境時使用。
如果要編譯 .NET Framewrok 項(xiàng)目,例如 4.6,請使用 MSBuild 14(對應(yīng) VS 2015),一般文件名稱為 BuildTools_Full_14.exe。
下載地址:
https://www.microsoft.com/en-US/download/details.aspx?id=48159
https://github.com/EWSoftware/SHFB/releases
安裝 MSBuild 后其目錄位置為:
C:\Program Files (x86)\MSBuild\14.0\Bin
請將其目錄路徑添加系統(tǒng)環(huán)境變量中。
Nuget
nuget 用于還原項(xiàng)目的依賴,對于 .NET Framework 項(xiàng)目,nuget 的版本不能為 5.0 以上,建議使用 4.5 版本左右,否則會有兼容問題!
安裝完畢后,nuget 程序目錄為:
C:\Program Files\nuget
請?zhí)砑幽夸浀较到y(tǒng)環(huán)境變量中。
安裝各種需要的工具后,環(huán)境變量一共需要添加以下項(xiàng):
C:\Program Files (x86)\MSBuild\14.0\Bin C:\Program Files\Git\cmd C:\Program Files\nuget C:\Program Files\Git\usr\bin C:\Program Files\IIS\Microsoft Web Deploy V3
請仔細(xì)檢查是否有遺留項(xiàng)。
配置項(xiàng)目
要脫離 VS 環(huán)境,自動化構(gòu)建 .NET Framework 應(yīng)用,需要處理的配置文件和環(huán)境很多,我們需要修改一下項(xiàng)目。在本節(jié)中,將介紹如何配置 .NET Framework 自動化流水線的構(gòu)建,使用 Jenkins 配置流水線,編寫 Jenkins 腳本等。
一般一個解決方案中,有一個是需要發(fā)布的主程序(主要為 Web 應(yīng)用),請為需要發(fā)布的 Web 項(xiàng)目,添加 Nuget 引用,搜索 MSBuild.Microsoft.VisualStudio.Web.targets
包,添加引用到項(xiàng)目中。
因?yàn)?.NET Framework 項(xiàng)目需要依賴 Vistual Studio 發(fā)布,如果不使用 VS 發(fā)布,會出現(xiàn)很多問題,為了脫離 VS 環(huán)境,有人封裝了一個完整的 targets 文件,指示 MSBuild 如何編譯此此程序。
對于需要發(fā)布的 Web 項(xiàng)目需要定義 Web 發(fā)布屬性,自動化構(gòu)建中,依賴這些提前配置的屬性,這些屬性會生成一個 .pubxml
文件,隨源代碼一起上傳到倉庫。
然后點(diǎn)擊發(fā)布,手動發(fā)布一次到一個目錄。
保存設(shè)置后,在項(xiàng)目的 Properties\PublishProfiles
目錄,可以找到 FolderProfile.pubxml 文件,其中有一行 PublishUrl
屬性,為網(wǎng)站發(fā)布時的輸出目錄。
<PublishUrl>C:\test</PublishUrl>
此目錄配置會影響到自動化構(gòu)建時的輸出,編譯時,生成的文件會輸出到這個目錄中,請確保在 Windows Jenkins 中,存儲此盤符!
然后直接在 Jenkins Web 上,操作即可。
前后端分類方案
當(dāng)我們?yōu)?.NET Core / .NET Framework 項(xiàng)目創(chuàng)建網(wǎng)站完畢,此時程序跟前端是一起的,打包發(fā)布不方便。
我們可以為前端項(xiàng)目新建一個無用的網(wǎng)站。
我可以編寫流水線腳本,將前端文件通過 WebDeploy 自動打包發(fā)布到此網(wǎng)站中。
接著,在后端網(wǎng)站中,添加一個虛擬目錄,目錄跟前端網(wǎng)站的目錄一致。
這樣,前后端都可以分開部署,而在后端網(wǎng)站后,可以直接讀取前端文件。
到此這篇關(guān)于Jenkins編譯.NET Core、.NET Framework項(xiàng)目并遠(yuǎn)程部署到IIS的文章就介紹到這了。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在.NET Core類庫中使用EF Core遷移數(shù)據(jù)庫到SQL Server的方法
下面小編就為大家分享一篇在.NET Core類庫中使用EF Core遷移數(shù)據(jù)庫到SQL Server的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12ASP.NET技巧:數(shù)據(jù)島出到Excel最為簡易的方法
ASP.NET技巧:數(shù)據(jù)島出到Excel最為簡易的方法...2006-09-09asp.net mvc4 mysql制作簡單分頁組件(部分視圖)
這篇文章主要介紹了asp.net mvc4 mysql制作簡單分頁組件,附部分視圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10