.Net 配置系统-数据库配置提供者

集群部署的项目中,如果每个服务器都使用本地的配置文件,每次修改都要挨个修改,费时费力还容易出错。

将配置信息放到数据库的表中,然后通过程序读取配置项,可以单独做一个配置服务器,其他服务器均从配置服务器中读取配置,避免了上述问题。

下面用示例展示用法:(数据库使用SqlServer,其他也可以)

1.数据库中建表T_Configs,三个字段Id、Name、Value,Id设置为主键并自增长。

.Net 配置系统-数据库配置提供者_第1张图片

.Net 配置系统-数据库配置提供者_第2张图片

往表中插入配置数据,支持json格式:

.Net 配置系统-数据库配置提供者_第3张图片

 程序需要引用的包:

.Net 配置系统-数据库配置提供者_第4张图片

Program.cs

using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using System;
using System.Data.SqlClient;

namespace DBConfigProvider
{
    class Program
    {
        static void Main(string[] args)
        {
            ServiceCollection services = new ServiceCollection();
            services.AddScoped();//往DI容器中注册自定义类
            ConfigurationBuilder configurationBuilder = new ConfigurationBuilder();

            string connStr = "server=.;DataBase=yzk;uid=sa;pwd=123456";//数据库连接

            //读取数据库表中的配置项并加载到ConfigurationBuilder
            configurationBuilder.AddDbConfiguration(() => new SqlConnection(connStr), reloadOnChange: true, reloadInterval: TimeSpan.FromSeconds(2));

            IConfigurationRoot root = configurationBuilder.Build();

            //将Options添加到DI容器中
            services.AddOptions()
                .Configure(e => root.Bind(e))//将CusConfig对象绑定到根节点上面
                .Configure(e => root.GetSection("proxy").Bind(e));

            //打印输出配置信息
            using (var sp = services.BuildServiceProvider())
            {
                var c = sp.GetRequiredService();
                c.Test();
                Console.ReadKey(); 
            }
        }


    }
}

CusConfig.cs

namespace DBConfigProvider
{
    class CusConfig
    {
        public string name { get; set; }
        public string age { get; set; }
        public Proxy proxy { get; set; }
    }

    class Proxy
    {
        public string address { get; set; }
        public int port { get; set; }
    }
}

TestWebConfig.cs

using Microsoft.Extensions.Options;
using System;

namespace DBConfigProvider
{
    class TestWebConfig
    {
        private IOptionsSnapshot optWC;

        public TestWebConfig(IOptionsSnapshot optWC)
        {
            this.optWC = optWC;
        }

        public void Test()
        {
            var wc = optWC.Value;
            Console.WriteLine(wc.name);
            Console.WriteLine(wc.age);
            Console.WriteLine(wc.proxy.address);
            Console.WriteLine(wc.proxy.port);
        }
    }
}

执行结果:

.Net 配置系统-数据库配置提供者_第5张图片

 

代码中调用的AddDbConfiguration方法,是杨中科老师自己开发的专门用于读取数据库配置的程序集。具体使用方法可以参考文档:

https://github.com/yangzhongke/Zack.AnyDBConfigProvider/blob/main/README_CHS.md

你可能感兴趣的:(杨中科.net6学习,配置,数据库配置,配置提供者)