Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dotnetcore/AgileConfig
基于.NET Core开发的轻量级分布式配置中心 / .NET Core lightweight configuration server
https://github.com/dotnetcore/AgileConfig
agileconfig configuration configuration-center configuration-management configuration-server dotnet-core microservice websocket
Last synced: 3 months ago
JSON representation
基于.NET Core开发的轻量级分布式配置中心 / .NET Core lightweight configuration server
- Host: GitHub
- URL: https://github.com/dotnetcore/AgileConfig
- Owner: dotnetcore
- License: mit
- Created: 2019-02-05T14:51:57.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-04T14:28:07.000Z (4 months ago)
- Last Synced: 2024-10-19T18:53:08.200Z (3 months ago)
- Topics: agileconfig, configuration, configuration-center, configuration-management, configuration-server, dotnet-core, microservice, websocket
- Language: C#
- Homepage:
- Size: 10.5 MB
- Stars: 1,503
- Watchers: 25
- Forks: 302
- Open Issues: 22
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: License.txt
Awesome Lists containing this project
- awesome - dotnetcore/AgileConfig - 基于.NET Core开发的轻量级分布式配置中心 / .NET Core lightweight configuration server (C\#)
README
AgileConfig
[![Member project of .NET Core Community](https://img.shields.io/badge/member%20project%20of-NCC-9e20c9.svg)](https://github.com/dotnetcore)
[![package workflow](https://github.com/dotnetcore/AgileConfig/actions/workflows/release-xxx.yml/badge.svg)](https://github.com/dotnetcore/AgileConfig/actions/workflows/release-xxx.yml)
![GitHub stars](https://img.shields.io/github/stars/kklldog/AgileConfig)
![Commit Date](https://img.shields.io/github/last-commit/kklldog/AgileConfig/master.svg?logo=github&logoColor=green&label=commit)
![Nuget](https://img.shields.io/nuget/v/agileconfig.client?label=agileconfig.client)
![Nuget](https://img.shields.io/nuget/dt/agileconfig.client?label=client%20download)
![Docker image](https://img.shields.io/docker/v/kklldog/agile_config?label=docker%20image)
![GitHub license](https://img.shields.io/github/license/kklldog/AgileConfig)
![build workflow](https://github.com/dotnetcore/AgileConfig/actions/workflows/master-ci.yml/badge.svg)
# [English](https://github.com/kklldog/AgileConfig/blob/master/README_EN.md) | [中文看这里](https://github.com/kklldog/AgileConfig/blob/master/README.md)
This is a lightweight configuration center based on .net core . It is easy to deploy , easy to learn , easy to use .
## 😍Features
1. easy to deploy (docker or IIS)
2. support distributed deploy
3. multiple environments support
4. configuration changes takes effect in real time
5. support IConfiguration , IOptions patten to read configurations
6. restful api
7. version management and easy to rollback
8. client fault tolerance
9. support OIDC/SSO
10. support OpenTelemetry
11. also can be use as a simple service register center
🔆🔆🔆Demo Project :[AgileConfig Server Demo](http://agileconfig_server.xbaby.xyz) name.pwd= admin/123456🔆🔆🔆
client project :[AgileConfig_Client](https://github.com/kklldog/AgileConfig_Client)
samples :
[AgileConfigMVCSample](https://github.com/kklldog/AgileConfig_Client/tree/master/AgileConfigMVCSample)
[AgileConfig WPFSample](https://github.com/kklldog/AgileConfig_Client/tree/master/AgileConfigWPFSample)
[AgileConfig ConsoleSample](https://github.com/kklldog/AgileConfig_Client/tree/master/AgileConfigConsoleSample)Q&A:
https://github.com/kklldog/AgileConfig/wiki
API:
[restful api](https://github.com/kklldog/AgileConfig/wiki/Restful-API)
## ChangeLog
[Changelog](https://github.com/kklldog/AgileConfig/blob/master/CHANGELOG.md)
## architecture
![](https://s1.ax1x.com/2020/06/29/NRz1gO.png)
### client
A .net client to read configurations from server node .### node
Node is just a .net core app . Client connect to the node in real time over websocket . Any node can be an admin console to manage configurations.
### database
AgileConfig support most popular databases.
dbprovider :
sqlserver = SqlServer
mysql = MySql
sqlite = Sqlite
npgsql = PostgreSql
oracle = Oracle
mongodb = Mongodb## ✅️How to use ?
### run node on docker
``` shell
sudo docker run \
--name agile_config \
-e TZ=Asia/Shanghai \
-e adminConsole=true \
-e db__provider=sqlite \
-e db__conn="Data Source=agile_config.db" \
-p 5000:5000 \
-v /etc/localtime:/etc/localtime \
#-v /your_host_dir:/app/db \
-d kklldog/agile_config:latest
```After the docker instance has successfully started you can visit http://localhost:5000 .
## use client
install client lib from nuget:
```
Install-Package AgileConfig.Client
```
add a section in appsettings.json of you application:
``` json
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Hosting.Lifetime": "Information"
}
},
"AllowedHosts": "*",//agile_config
"AgileConfig": {
"appId": "app",
"secret": "xxx",
"nodes": "http://localhost:5000,http://localhost:5001",
"name": "client_name",
"tag": "tag1",
"env": "dev"
}
}```
in Main function add agileconfig client services:
``` c#
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.UseAgileConfig()
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup();
});
```## read configuration
You can still use `IConfiguration` or `IOption` patten to get the specific configuration value.
``` c#
public class HomeController : Controller
{
private readonly IConfiguration _IConfiguration;
private readonly IOptions _dbOptions;public HomeController(IConfiguration configuration, IOptions dbOptions)
{
_IConfiguration = configuration;
_dbOptions = dbOptions;
}
}
```Or you can use `IConfigClient` interface to get the specific configuration value.
``` c#
public class HomeController : Controller
{
private readonly IConfigClient _configClientpublic HomeController(IConfigClient configClient)
{
_configClient = configClient;
}///
/// By IConfigClient
///
///
public IActionResult ByIConfigClient()
{
var userId = _configClient["userId"];
var dbConn = _configClient["db:connection"];foreach (var item in _configClient.Data)
{
Console.WriteLine($"{item.Key} = {item.Value}");
}ViewBag.userId = userId;
ViewBag.dbConn = dbConn;return View();
}
}
```
Or you can use a signleton instance without any injection.
``` c#
var userid = ConfigClient.Instance["userid"]
```## donate
If this project is helpful to you, please scan the QR code below for a cup of coffee.
## thanks 💖💖💖
大鹏¥66.66 , 瘦草¥6.66 + 88 , ziana¥10.0 , Nullable¥9.99 , *三 ¥6.66 , HHM ¥6.66 , *。 ¥6.66 , 微笑刺客 ¥6.66 ,飞鸟与鱼 ¥38.88, *航 ¥9.9, *啦 ¥6.66, *海 ¥6.66, Dyx 邓杨喜 ¥30 And more ...
## contact me
mail:[email protected]
🐧 group:1022985150