.NET 開(kāi)源配置組件 AgileConfig的使用簡(jiǎn)介
介紹
在微服務(wù)大行其道的今天,系統(tǒng)會(huì)被拆分成多個(gè)模塊,作為單獨(dú)的服務(wù)運(yùn)行,同時(shí)為了集中化管理,我們還需要日志中心,配置中心等,很多開(kāi)發(fā)人員可能更熟悉 ApolloConfig,這個(gè)組件功能也很完善,dotnet的客戶(hù)端也主要是國(guó)人在維護(hù)和開(kāi)發(fā),之前公司就是選型的Apollo,而且也在生產(chǎn)環(huán)境穩(wěn)定運(yùn)行,但是服務(wù)端是Java的,而且部署服務(wù)端也有些麻煩。
今天主要介紹 AgileConfig,這是一個(gè)基于.net core開(kāi)發(fā)的輕量級(jí)配置中心,之前跟作者也有過(guò)溝通,也很熱情幫忙解決問(wèn)題,它的特點(diǎn)有部署簡(jiǎn)單、配置簡(jiǎn)單、使用簡(jiǎn)單、學(xué)習(xí)簡(jiǎn)單等,同時(shí)也支持高可用(多節(jié)點(diǎn))和docker部署,使用了FreeSql支持了多種多種數(shù)據(jù)庫(kù)存儲(chǔ),Sqlserver, Mysql, Sqlite, PostgreSql,Oracle,F(xiàn)reeSql大法好!
架構(gòu)圖

部署服務(wù)端
首先,我們需要部署服務(wù)端,包含了控制臺(tái)UI和節(jié)點(diǎn)服務(wù),節(jié)點(diǎn)服務(wù)使用了長(zhǎng)連接,配置變更后,會(huì)實(shí)時(shí)推送給客戶(hù)端,部署推薦使用docker部署,因?yàn)轫?xiàng)目是開(kāi)源的,而且是.net core 編寫(xiě)的,還有一種方式是可以到github下載源代碼,編譯后發(fā)布運(yùn)行。
配置信息是在數(shù)據(jù)庫(kù)記錄的,我們需要新建一個(gè)空的數(shù)據(jù)庫(kù),然后運(yùn)行命令,程序會(huì)自動(dòng)幫我們初始化表結(jié)構(gòu)和數(shù)據(jù)。
docker run --name agile_config -e adminConsole=true -e db:provider=mysql -e db:conn="DataBase=configdb;Data Source=host.docker.internal;User Id=root;Password=123456;" -p 5000:5000 -d kklldog/agile_config:latest
參數(shù)介紹:
- adminConsole 配置程序是否為管理控制臺(tái),如果為true則啟用控制臺(tái)功能,訪(fǎng)問(wèn)該實(shí)例會(huì)出現(xiàn)管理界面,多節(jié)點(diǎn)部署的話(huà),只需要開(kāi)啟一個(gè)控制臺(tái)即可。
- db:provider 配置程序的數(shù)據(jù)庫(kù)類(lèi)型,可選 sqlserver,mysql,sqlite,npgsql,oracle。
- db:conn 配置數(shù)據(jù)庫(kù)連接串
訪(fǎng)問(wèn) http://localhost:5000/, 第一次啟動(dòng),程序會(huì)要求我們初始化管理員密碼,設(shè)置完成以后,進(jìn)入到首頁(yè),另外作者最近已經(jīng)用 React 重構(gòu)了UI,最近會(huì)更新,大家也可以嘗鮮。

然后還需要配置節(jié)點(diǎn),多節(jié)點(diǎn)保證了高可用,那如果所有節(jié)點(diǎn)都掛了的話(huà),程序會(huì)讀取本地的配置緩存,來(lái)保證正常的運(yùn)行,這點(diǎn)大家不用擔(dān)心, 我們需要在節(jié)點(diǎn)管理頁(yè)面手動(dòng)添加節(jié)點(diǎn),這里我啟動(dòng)了一個(gè)節(jié)點(diǎn),添加的地址為 http://192.168.100.103:5000 ,需要注意的是,這里在docker環(huán)境不能使用 localhost。

接下來(lái)需要配置應(yīng)用,點(diǎn)擊新增應(yīng)用,填寫(xiě)應(yīng)用名稱(chēng),應(yīng)用Id和應(yīng)用密鑰。

在客戶(hù)端程序使用
這里使用了asp net core web項(xiàng)目示例,首先需要安裝客戶(hù)端組件,執(zhí)行一下命令或者通過(guò)Nuget安裝。
Install-Package AgileConfig.Client
然后修改appsetting.json 文件
{
"AgileConfig": {
"appId": "LogService",
"secret": "123456",
"nodes": "http://localhost:5000,http://localhost:5001"http://多個(gè)節(jié)點(diǎn)使用逗號(hào)分隔
}
}
然后修改 Program.cs
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureAppConfiguration((context, config) =>
{
var configClient = new ConfigClient();
config.AddAgileConfig(configClient);
})
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
});
準(zhǔn)備工作完成,接下來(lái)就要開(kāi)始使用了,我們?cè)谂渲庙?xiàng)頁(yè)面上面添加配置,然后選中點(diǎn)擊上線(xiàn)。

然后可以在代碼中使用注入的 IConfiguration 獲取配置即可
[Route("[controller]/[action]")]
public class HomeController : ControllerBase
{
private readonly IConfiguration _config;
public HomeController(IConfiguration config)
{
_config = config;
}
[HttpGet]
public IActionResult Index()
{
var value = _config["AgileKey"];
return Ok(new { value });
}
然后啟動(dòng)程序,就可以盡情使用 AgileConfig 了,在頁(yè)面上修改配置的話(huà),我們的客戶(hù)端配置也是實(shí)時(shí)修改的。
在配置頁(yè)面上的配置都是字符串鍵值對(duì)的,那對(duì)于Json字符串應(yīng)該怎么處理呢, 我們可以使用 Tuhu.Extensions.Configuration.ValueBinder.Json 擴(kuò)展,通過(guò)Nuget安裝即可,然后修改Startup.cs 文件
public void ConfigureServices(IServiceCollection services)
{
services.ConfigureJsonValue<LogOptions>("", Configuration.GetSection("LogOptions"));
}
LogOptions:
public class LogOptions : IOptions<LogOptions>
{
public string Level { get; set; }
public int Count { get; set; }
public LogOptions Value => this;
}
這樣我們就可以在代碼中,使用注入的 IOptions<LogOptions> 來(lái)獲取讀取配置。
總結(jié)
AgileConfig 是使用 .net core 開(kāi)發(fā)的配置組件,部署和使用起來(lái)都很簡(jiǎn)單,但是目前還有一些不足,比如多賬號(hào)權(quán)限管理,和多環(huán)境支持,一般是開(kāi)發(fā),灰度和正式,不過(guò)沒(méi)有關(guān)系,項(xiàng)目都是開(kāi)源的,大家感興趣的一起建設(shè),完善不足的功能,現(xiàn)在.NET 社區(qū)是越來(lái)越好了,如果對(duì)大家有幫助的,可以支持一下!
https://github.com/kklldog/AgileConfig
以上就是.NET 開(kāi)源配置組件 AgileConfig的使用簡(jiǎn)介的詳細(xì)內(nèi)容,更多關(guān)于.NET 開(kāi)源配置組件 AgileConfig的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- ASP.NET開(kāi)源導(dǎo)入導(dǎo)出庫(kù)Magicodes.IE完成Csv導(dǎo)入導(dǎo)出的方法
- 詳解開(kāi)源免費(fèi)且穩(wěn)定實(shí)用的.NET PDF打印組件itextSharp(.NET組件介紹之八)
- 詳解一款開(kāi)源免費(fèi)的.NET文檔操作組件DocX(.NET組件介紹之一)
- 詳解免費(fèi)開(kāi)源的DotNet二維碼操作組件ThoughtWorks.QRCode(.NET組件介紹之四)
- 詳解免費(fèi)開(kāi)源的.NET多類(lèi)型文件解壓縮組件SharpZipLib(.NET組件介紹之七)
- 詳解最好的.NET開(kāi)源免費(fèi)ZIP庫(kù)DotNetZip(.NET組件介紹之三)
- 詳解免費(fèi)開(kāi)源的DotNet任務(wù)調(diào)度組件Quartz.NET(.NET組件介紹之五)
- .NET中開(kāi)源文檔操作組件DocX的介紹與使用
- 基于.NET平臺(tái)常用的框架和開(kāi)源程序整理
- .NET 開(kāi)源項(xiàng)目Polly的簡(jiǎn)單介紹
相關(guān)文章
asp.net使用jQuery Uploadify上傳附件示例
Uploadify是JQuery的一個(gè)上傳插件,實(shí)現(xiàn)的效果非常不錯(cuò),帶進(jìn)度顯示,本文是一個(gè)簡(jiǎn)單的介紹Demo,主要是動(dòng)態(tài)傳遞參數(shù)方法,通過(guò)formdata 向處理程序傳遞額外的表單數(shù)據(jù)2014-01-01
ASP.NET性能優(yōu)化之讓瀏覽器緩存動(dòng)態(tài)網(wǎng)頁(yè)的方法
上一篇《ASP.NET性能優(yōu)化之構(gòu)建自定義文件緩存》我們通過(guò)OutputCache,讓請(qǐng)求去訪(fǎng)問(wèn)服務(wù)器asp.net的輸出緩存,我們擴(kuò)展了OutputCacheProvider,這相當(dāng)于是訪(fǎng)問(wèn)服務(wù)器上的靜態(tài)資源。2011-09-09
.NET下實(shí)現(xiàn)數(shù)字和字符相混合的驗(yàn)證碼實(shí)例
這篇文章介紹了.NET下實(shí)現(xiàn)數(shù)字和字符相混合的驗(yàn)證碼實(shí)例,有需要的朋友可以參考一下2013-11-11
Visual Studio 2017+OpenCV環(huán)境搭建教程
這篇文章主要為大家詳細(xì)介紹了Visual Studio 2017+OpenCV環(huán)境搭建教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
ASP.NET對(duì)路徑"xxxxx"的訪(fǎng)問(wèn)被拒絕的解決方法小結(jié)
異常詳細(xì)信息: System.UnauthorizedAccessException: 對(duì)路徑“D:/temp1/MyTest.txt”的訪(fǎng)問(wèn)被拒絕2012-09-09
Asp.net FileUpload上傳文件夾并檢測(cè)所有子文件的實(shí)現(xiàn)代碼
這篇文章主要介紹了Asp.net FileUpload上傳文件夾并檢測(cè)所有子文件的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-05-05
ASP.NET Core MVC通過(guò)IViewLocationExpander擴(kuò)展視圖搜索路徑的實(shí)現(xiàn)
這篇文章主要介紹了ASP.NET Core MVC通過(guò)IViewLocationExpander擴(kuò)展視圖搜索路徑的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04

