• .net 分布式架构之配置中心


    开源QQ群: .net 开源基础服务  238543768

    开源地址: http://git.oschina.net/chejiangyi/Dyd.BaseService.ConfigManager

    .net 统一配置中心

    用于所有项目统一的配置集中管理,简化运维和项目部署,具备高灵活性,高性能,高稳定性,高及时性。
    同时具备配置项的负载均衡和故障转移,从而实现项目的软性的负载均衡和故障转移能力。

    1.高灵活性
    一个项目可以自由组合或者继承多个分类配置,多个分类的相同配置项可以被子分类配置项覆盖。
    (举例:项目A可以组合使用“基础数据库配置”,“基础监控配置”,“基础日志配置”,“项目A配置”;项目A配置可以定义自身的特殊配置和覆盖一些基础配置)

    2.高稳定性
    sdk(客户端)默认会在“本地”保存项目的所有配置“快照”,若统一配置中心异常,sdk将从上一次可用“快照”获取配置,并在配置中心恢复后,获取最新版本。

    3.高性能
    sdk(客户端)默认在本地内存中缓存“最新版本”的项目配置,sdk获取的配置都从内存版本中获取。

    4.高及时性
      4.1 sdk(客户端)默认心跳时间内连接配置中心获取最新配置修改。
      4.2 web端的配置修改,通过第三方消息中间件及时通知相关sdk至配置中心获取最新修改。
      4.3 web端可以重启相关分类/相关项目的客户端,重新初始化所有的配置信息。

    5.软性负载均衡
    可以在web端手工配置某个配置的负载均衡(可以配置不同的使用权重命中不同的负载均衡配置)
    (若要自动,请编写任务挂载到“任务调度”中,根据业务情况,动态调整负载均衡权重。参考openapi接口)

    6.软性故障转移
    可以在web端手工配置某个配置的故障转移。
    (若要自动,请编写任务挂载到“任务调度”中,根据业务情况,动态监测当前配置的故障情况,然后选择使用备用故障配置。参考openapi接口)

    使用demo

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using XXF.BaseService.ConfigManager;//使用ConfigManager命名空间
    
    namespace Dyd.BaseService.ConfigManager.Test
    {
        /*
         * 配置中心使用demo
         */
        public class ConfigManagerDemo
        {
            /// <summary>
            /// 配置中心基本配置初始化
            /// </summary>
            public void InitConfig()
            {
                XXF.Common.XXFConfig.ProjectName = "projecttest";//当前项目名称,项目代码配置或者从App.config/web.config读取
                XXF.Common.XXFConfig.ConfigManagerConnectString = "server=192.168.17.111;Initial Catalog=dyd_bs_config;User ID=sa;Password=123456;";//配置中心管理数据库,项目代码配置或者从App.config/web.config读取
            }
            /// <summary>
            /// 使用demo
            /// </summary>
            public void UseDemo()
            {
                /*
                 * 配置获取优先级
                 * 1.从本地app.config,web.config中优先获取
                 * 2.从配置中心获取次之。
                 */
                string configkey = "configkey1";
                var value = ConfigManagerHelper.Get<string>(configkey);//获取配置值
                
            }
        }
    }

    部分截图

    by 车江毅

  • 相关阅读:
    关于我的介绍
    关于这周的作业
    关于这周的学习
    每周学习
    关于这周程序设计
    关于这周的总结
    关于这周的学习
    随机抽签程序报告
    Mysql的主从复制原理及部署
    项目架构脚本
  • 原文地址:https://www.cnblogs.com/chejiangyi/p/4988072.html
Copyright © 2020-2023  润新知