.NET 開源配置組件 AgileConfig的使用簡介
介紹
在微服務(wù)大行其道的今天,系統(tǒng)會被拆分成多個模塊,作為單獨的服務(wù)運行,同時為了集中化管理,我們還需要日志中心,配置中心等,很多開發(fā)人員可能更熟悉 ApolloConfig,這個組件功能也很完善,dotnet的客戶端也主要是國人在維護和開發(fā),之前公司就是選型的Apollo,而且也在生產(chǎn)環(huán)境穩(wěn)定運行,但是服務(wù)端是Java的,而且部署服務(wù)端也有些麻煩。
今天主要介紹 AgileConfig,這是一個基于.net core開發(fā)的輕量級配置中心,之前跟作者也有過溝通,也很熱情幫忙解決問題,它的特點有部署簡單、配置簡單、使用簡單、學習簡單等,同時也支持高可用(多節(jié)點)和docker部署,使用了FreeSql支持了多種多種數(shù)據(jù)庫存儲,Sqlserver, Mysql, Sqlite, PostgreSql,Oracle,F(xiàn)reeSql大法好!
架構(gòu)圖
部署服務(wù)端
首先,我們需要部署服務(wù)端,包含了控制臺UI和節(jié)點服務(wù),節(jié)點服務(wù)使用了長連接,配置變更后,會實時推送給客戶端,部署推薦使用docker部署,因為項目是開源的,而且是.net core 編寫的,還有一種方式是可以到github下載源代碼,編譯后發(fā)布運行。
配置信息是在數(shù)據(jù)庫記錄的,我們需要新建一個空的數(shù)據(jù)庫,然后運行命令,程序會自動幫我們初始化表結(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 配置程序是否為管理控制臺,如果為true則啟用控制臺功能,訪問該實例會出現(xiàn)管理界面,多節(jié)點部署的話,只需要開啟一個控制臺即可。
- db:provider 配置程序的數(shù)據(jù)庫類型,可選 sqlserver,mysql,sqlite,npgsql,oracle。
- db:conn 配置數(shù)據(jù)庫連接串
訪問 http://localhost:5000/, 第一次啟動,程序會要求我們初始化管理員密碼,設(shè)置完成以后,進入到首頁,另外作者最近已經(jīng)用 React 重構(gòu)了UI,最近會更新,大家也可以嘗鮮。
然后還需要配置節(jié)點,多節(jié)點保證了高可用,那如果所有節(jié)點都掛了的話,程序會讀取本地的配置緩存,來保證正常的運行,這點大家不用擔心, 我們需要在節(jié)點管理頁面手動添加節(jié)點,這里我啟動了一個節(jié)點,添加的地址為 http://192.168.100.103:5000 ,需要注意的是,這里在docker環(huán)境不能使用 localhost。
接下來需要配置應(yīng)用,點擊新增應(yīng)用,填寫應(yīng)用名稱,應(yīng)用Id和應(yīng)用密鑰。
在客戶端程序使用
這里使用了asp net core web項目示例,首先需要安裝客戶端組件,執(zhí)行一下命令或者通過Nuget安裝。
Install-Package AgileConfig.Client
然后修改appsetting.json 文件
{ "AgileConfig": { "appId": "LogService", "secret": "123456", "nodes": "http://localhost:5000,http://localhost:5001"http://多個節(jié)點使用逗號分隔 } }
然后修改 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>(); });
準備工作完成,接下來就要開始使用了,我們在配置項頁面上面添加配置,然后選中點擊上線。
然后可以在代碼中使用注入的 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 }); }
然后啟動程序,就可以盡情使用 AgileConfig 了,在頁面上修改配置的話,我們的客戶端配置也是實時修改的。
在配置頁面上的配置都是字符串鍵值對的,那對于Json字符串應(yīng)該怎么處理呢, 我們可以使用 Tuhu.Extensions.Configuration.ValueBinder.Json
擴展,通過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>
來獲取讀取配置。
總結(jié)
AgileConfig 是使用 .net core 開發(fā)的配置組件,部署和使用起來都很簡單,但是目前還有一些不足,比如多賬號權(quán)限管理,和多環(huán)境支持,一般是開發(fā),灰度和正式,不過沒有關(guān)系,項目都是開源的,大家感興趣的一起建設(shè),完善不足的功能,現(xiàn)在.NET 社區(qū)是越來越好了,如果對大家有幫助的,可以支持一下!
https://github.com/kklldog/AgileConfig
以上就是.NET 開源配置組件 AgileConfig的使用簡介的詳細內(nèi)容,更多關(guān)于.NET 開源配置組件 AgileConfig的資料請關(guān)注腳本之家其它相關(guān)文章!
- ASP.NET開源導入導出庫Magicodes.IE完成Csv導入導出的方法
- 詳解開源免費且穩(wěn)定實用的.NET PDF打印組件itextSharp(.NET組件介紹之八)
- 詳解一款開源免費的.NET文檔操作組件DocX(.NET組件介紹之一)
- 詳解免費開源的DotNet二維碼操作組件ThoughtWorks.QRCode(.NET組件介紹之四)
- 詳解免費開源的.NET多類型文件解壓縮組件SharpZipLib(.NET組件介紹之七)
- 詳解最好的.NET開源免費ZIP庫DotNetZip(.NET組件介紹之三)
- 詳解免費開源的DotNet任務(wù)調(diào)度組件Quartz.NET(.NET組件介紹之五)
- .NET中開源文檔操作組件DocX的介紹與使用
- 基于.NET平臺常用的框架和開源程序整理
- .NET 開源項目Polly的簡單介紹
相關(guān)文章
Asp.net core中實現(xiàn)自動更新的Option的方法示例
這篇文章主要介紹了Asp.net core中實現(xiàn)自動更新的Option的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-03-03