欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

.NET 开源配置组件 AgileConfig的使用简介

程序员文章站 2022-05-11 19:34:43
介绍在微服务大行其道的今天,系统会被拆分成多个模块,作为单独的服务运行,同时为了集中化管理,我们还需要日志中心,配置中心等,很多开发人员可能更熟悉 apolloconfig,这个组件功能也很完善,do...

介绍

在微服务大行其道的今天,系统会被拆分成多个模块,作为单独的服务运行,同时为了集中化管理,我们还需要日志中心,配置中心等,很多开发人员可能更熟悉 apolloconfig,这个组件功能也很完善,dotnet的客户端也主要是国人在维护和开发,之前公司就是选型的apollo,而且也在生产环境稳定运行,但是服务端是java的,而且部署服务端也有些麻烦。

今天主要介绍 agileconfig,这是一个基于.net core开发的轻量级配置中心,之前跟作者也有过沟通,也很热情帮忙解决问题,它的特点有部署简单、配置简单、使用简单、学习简单等,同时也支持高可用(多节点)和docker部署,使用了freesql支持了多种多种数据库存储,sqlserver, mysql, sqlite, postgresql,oracle,freesql大法好!

架构图

.NET 开源配置组件 AgileConfig的使用简介

部署服务端

首先,我们需要部署服务端,包含了控制台ui和节点服务,节点服务使用了长连接,配置变更后,会实时推送给客户端,部署推荐使用docker部署,因为项目是开源的,而且是.net core 编写的,还有一种方式是可以到github下载源代码,编译后发布运行。

配置信息是在数据库记录的,我们需要新建一个空的数据库,然后运行命令,程序会自动帮我们初始化表结构和数据。

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

参数介绍:

  • adminconsole 配置程序是否为管理控制台,如果为true则启用控制台功能,访问该实例会出现管理界面,多节点部署的话,只需要开启一个控制台即可。
  • db:provider 配置程序的数据库类型,可选 sqlserver,mysql,sqlite,npgsql,oracle。
  • db:conn 配置数据库连接串

访问 http://localhost:5000/, 第一次启动,程序会要求我们初始化管理员密码,设置完成以后,进入到首页,另外作者最近已经用 react 重构了ui,最近会更新,大家也可以尝鲜。

.NET 开源配置组件 AgileConfig的使用简介

然后还需要配置节点,多节点保证了高可用,那如果所有节点都挂了的话,程序会读取本地的配置缓存,来保证正常的运行,这点大家不用担心, 我们需要在节点管理页面手动添加节点,这里我启动了一个节点,添加的地址为 ,需要注意的是,这里在docker环境不能使用 localhost。

.NET 开源配置组件 AgileConfig的使用简介

接下来需要配置应用,点击新增应用,填写应用名称,应用id和应用密钥。

.NET 开源配置组件 AgileConfig的使用简介

在客户端程序使用

这里使用了asp net core web项目示例,首先需要安装客户端组件,执行一下命令或者通过nuget安装。

install-package agileconfig.client

然后修改appsetting.json 文件

{ 
  "agileconfig": {
    "appid": "logservice",
    "secret": "123456",
    "nodes": "http://localhost:5000,http://localhost:5001"//多个节点使用逗号分隔
  }
}

然后修改 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>();
        });

准备工作完成,接下来就要开始使用了,我们在配置项页面上面添加配置,然后选中点击上线。

.NET 开源配置组件 AgileConfig的使用简介

然后可以在代码中使用注入的 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字符串应该怎么处理呢, 我们可以使用 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> 来获取读取配置。

总结

agileconfig 是使用 .net core 开发的配置组件,部署和使用起来都很简单,但是目前还有一些不足,比如多账号权限管理,和多环境支持,一般是开发,灰度和正式,不过没有关系,项目都是开源的,大家感兴趣的一起建设,完善不足的功能,现在.net 社区是越来越好了,如果对大家有帮助的,可以支持一下!

https://github.com/kklldog/agileconfig

以上就是.net 开源配置组件 agileconfig的使用简介的详细内容,更多关于.net 开源配置组件 agileconfig的资料请关注其它相关文章!