前言 隨著近些年微服務的流行,有越來越多的開發者和團隊所採納和使用,它的確提供了很多的優勢也解決了很多的問題,但是我們也知道也並不是銀彈,提供優勢的同時它也給我們的開發人員和團隊也帶來了很多的挑戰。 為了迎接或者採用這些新技術,開發團隊需要更加註重一些流程或工具的使用,這樣才能更好的適應這些新技術所 ...
前言
隨著近些年微服務的流行,有越來越多的開發者和團隊所採納和使用,它的確提供了很多的優勢也解決了很多的問題,但是我們也知道也並不是銀彈,提供優勢的同時它也給我們的開發人員和團隊也帶來了很多的挑戰。
為了迎接或者採用這些新技術,開發團隊需要更加註重一些流程或工具的使用,這樣才能更好的適應這些新技術所帶來的一些問題。 對於流程行問題,敏捷的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