前言
隨著近些年微服務的流行,有越來越多的開發者和團隊所采納和使用,它的確提供了很多的優勢也解決了很多的問題,但是我們也知道也并不是銀彈,提供優勢的同時它也給我們的開發人員和團隊也帶來了很多的挑戰,
為了迎接或者采用這些新技術,開發團隊需要更加注重一些流程或工具的使用,這樣才能更好的適應這些新技術所帶來的一些問題, 對于流程行問題,敏捷的Scrum能夠很好的提升產品開發團隊之間的協作問題,那么對于應用變的越來越復雜這種情況,它最直接的問題就是帶來了開發運維的復雜性,這個時候我們就需要使用工具來解決了,
開發運維的復雜性
從字面意思可以看出開發運維的復雜性指的是開發的復雜以及運維的復雜,然后我們具體來說一下到底是怎么復雜的,
我們先說開發的復雜性, 應用由單體變成分布式,需要處理分布式系統遇到的所有問題, 我在之前的博客里面大致都說過遇到的一些挑戰,感興趣的同學可以跳過去看下,
除此之外就是遇到的另外一個也會導致變得復雜就是應用的構建和發布以及部署,因為涉及到的服務特別多就帶來了很多的問題,所以遇到的這些問題你可以認為應該開發處理也可以認為應該運維處理,那么就合在一起叫開發運維問題吧,
針對這種開發運維問題,業內提出了DevOps支持,
DevOps
DevOps (Development和Operations的組合詞),他是一組程序、方法與系統的統稱,用于促進開發(應用程式/軟體工程)、技術運營和質量保障(QA)部門之間的溝通、協作與整合,
這種整合在微服務團隊變得尤其重要,在整合的程序中需要用到很多的一些工具來解決遇到的問題,總之一圖勝千言,

從上圖可以看出在 Build 和 CI/CD 階段需要用到很多的工具,我們需要寫腳本對這些工具進行呼叫以便于讓他們能夠協同作業,通常我們會使用 shell 腳本,然后來呼叫這些工具提供的 cli 命令列,然后由構建平臺來觸發,比如 Jenkins 或者 GitLab CI, Team City 等等,
那么對于不熟悉 shell 的同學,或者覺得使用 shell 效率太低又不方便維護有沒有其他的工具可以使用呢,最好是C#可以直接寫? 答案當然是有的,今天就給大家強烈推薦一款利器 FlubuCore.
FlubuCore 是什么?

FlubuCore 是一個跨平臺的自動化構建和部署系統,用于使用C#代碼構建專案和執行部署腳本,
Github: https://github.com/dotnetcore/FlubuCore
檔案:https://flubucore-zh.dotnetcore.xyz/
FlubuCore 基于 MIT 協議開源,目前已經是 .NET Foundation 基金會專案成員,作者(Marko Zorec)也是我們 NCC 的核心專案成員之一,
現在你可以利用 C# 去撰寫構建和部署腳本,同時支持 .NET Framework 和 .NET Core,不需要再去學習其他工具或語言了,而且 FlubuCore 提供了一套 Fluent 式的 API,讓你寫起來根本停不下來, 看圖:

香不香? 快去 Github 點個 Star 支持一下吧,你的一個小小的 Star 也是對整個 .NET 生態的貢獻,
FlubuCore Getting Started
雖然 FlubuCore 提供的有中文的 Readme,不過我還是簡單的帶大家入個門吧,
1. 安裝全域命令列工具
打開 CMD 執行一下命令:
dotnet tool install --global FlubuCore.GlobalTool
這個命令的主要作用是安裝一個全域的命令列工具,持續集成的平臺后續就可以利用 flube 這個命令列工具來執行C#自定義的腳本,
2. 新建一個空的解決方案
mkdir FlubuTest
cd FlubuTest
dotnet new sln
mkdir src
cd src
mkdir mywebapp
cd mywebapp
dotnet new webapp
dotnet sln ../../FlubuTest.sln add ./mywebapp.csproj
覺得麻煩的,Visual Studio 直接新建就可以搞定了,
3. 添加 Flubucore 構建專案
先切換到第2步的解決方案根目錄 cd ../../,然后創建build的入口專案:
dotnet new -i FlubuCore.Template
dotnet new FlubuCore
dotnet sln FlubuTest.sln add ./BuildScript/BuildScript.csproj
將 FlubuCore 添加到解決方案主要是后續撰寫腳本的方便,借助于 VisualStudio 的智能提示等就像撰寫C#代碼一樣了,實際上就是C#代碼, 當然也可以選擇不添加到專案中,
最后的檔案夾結構大概是這個樣子的:
│──FlubuTest.sln
│
└──BuildScript
│ │ BuildScript.cs
│ │ BuildScript.csproj
└─src
└─mywebapp
│ appsettings.Development.json
│ appsettings.json
│ mywebapp.csproj
│ Program.cs
│ Startup.cs
4. 修改 BuildScript.cs 檔案
打開 BuildScript/BuildScript.cs 然后將
context.Properties.Set(BuildProps.SolutionFileName, "Todo");
Todo 修改為解決方案的名字
context.Properties.Set(BuildProps.SolutionFileName, "FlubeTest.sln");
BuildProps 這個物件主要提供了在構建的程序中一些背景關系資訊,通過設定此物件你可以給flubu 提供更多資訊以便于后續的使用等,
5. 開始使用
在專案根目錄打開 cmd, 然后使用下面的命令來編譯你的專案,
flubu compile
其中 compile 就是檔案 _Build/BuildScript/BuildScript.cs 的這段代碼里面的 compile,你可以隨意更改,只需要和命令保持一致,
protected override void ConfigureTargets(ITaskContext context)
{
var compile = context.CreateTarget("compile")
.SetDescription("Compiles the solution.")
.AddCoreTask(x => x.Build());
}
后面基本上你需要的構建的所有的東西都可以寫到 ConfigureTargets 里面了,
最后的輸出:
D:\FlubuTest>flubu compile
Flubu v.4.3.5.0
Build script file name was not explicitly specified, searching the default locations:
Found it, using the build script file 'BuildScript/BuildScript.cs'.
Executing target compile
Executing task DotnetBuildTask
Running program 'C:\Program Files\dotnet\dotnet.exe':(work.dir='',args=' build FlubuTest.sln')
用于 .NET Core 的 Microsoft (R) 生成引擎版本 16.6.0+5ff7b0c9e
著作權所有(C) Microsoft Corporation,保留所有權利,
正在確定要還原的專案…
所有專案均是最新的,無法還原,
BuildScript -> D:\FlubuTest\BuildScript\bin\Debug\netcoreapp2.1\BuildScript.dll
mywebapp -> D:\FlubuTest\src\mywebapp\bin\Debug\netcoreapp3.1\mywebapp.dll
mywebapp -> D:\FlubuTest\src\mywebapp\bin\Debug\netcoreapp3.1\mywebapp.Views.dll
已成功生成,
0 個警告
0 個錯誤
已用時間 00:00:02.51
compile finished (took 3 seconds)
BUILD SUCCESSFUL
Build finish time: 2020/7/4 0:47
Build duration: 00:00:03 (3 seconds)
可能有人會問,這和我用 dotnet build FlubuTest.sln 有區別嗎?
針對這個示例而言,是沒區別,但是你可以自己擴展啊,擴展后不就有區別了,比如你想build之前先清理檔案夾之類的,可以這么寫,
var compile = context.CreateTarget("compile")
.SetDescription("Compiles the solution.")
.AddCoreTask(x => x.Clean())
.AddCoreTask(x => x.Build());
借助于 flubu 提供的能力,可以在 CI/CD 界面解決很多復雜的構建問題,
總結
上面的僅僅是一個入門,如果你覺得你們專案剛好需要那么你可以去官方的檔案去查看,里面有更加詳細的使用指南,當然也可以在這個博客下面留言或者去GitHub提交issue詢問,
GitHub: https://github.com/dotnetcore/FlubuCore
FlubuCore 給我們提供了一種可以快速撰寫 DevOps 腳本的能力,利用這種能力可以讓DevOps變得更加簡單和高效,從而提高效率節約時間,
如果你覺得本篇文章對您有幫助的話,感謝您的【推薦】,
本文地址:http://www.cnblogs.com/savorboard/p/flubucore.html
作者博客:Savorboard
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/6413.html
標籤:C#
上一篇:C#使用FFmpeg的總結
