.NET Core - 选项框架:服务组件集成配置的最佳实践

简介: .NET Core - 选项框架:服务组件集成配置的最佳实践

本节来学习选项框架的使用,通过本节,你将理解如题所示的服务组件集成配置的最佳实践。

我们定义一个IOrderService接口,接口包含一个ShowMaxOrderCount方法

public interface IOrderService
{
    void ShowMaxOrderCount();
}

定义一个OrderService服务实现这个接口

public class OrderService : IOrderService
{
    OrderOptions orderOptions;
    public OrderService(OrderOptions orderOptions)
    {
        this.orderOptions = orderOptions;
    } 
    public void ShowMaxOrderCount()
    {
        Console.WriteLine($"MaxOrderCount:{orderOptions.MaxOrderCount}");
    }
}

同时,我们定义一个类用来承载配置数据。

public class OrderOptions
{
    public int MaxOrderCount { get; set; } = 100;
    public int TotalCount { get; set; } = 500;
}

这样,我们通过将该服务注册到根容器之后,就可以通过前端来调用该服务方法了。

//根容器注册
services.AddSingleton<OrderOptions>();
services.AddSingleton<IOrderService, OrderService>();
//前端调用服务
[HttpGet]
public void Get([FromServices]IOrderService service)
{
    service.ShowMaxOrderCount();
}

但是,我们的配置肯定是会不停变化的,因此,我们需要从配置中读取值并绑定到配置类上,比如如下配置

{
  //...省略不必要的
  "MaxOrderCount": {
    "MaxOrderCount": 2000,
    "TotalCount": 1000
  }
}

其实,我们当然可以通过学习配置框架强类型绑定时的方式,将配置绑定到配置类来实现,但是这样的话,我们的服务就要依赖配置框架了。为了实现松耦合,微软为我们提供了选项框架来处理这种情形。

IOptions

当我们使用选项框架时,只需要用IOptions<>来包装我们的配置类,然后更改配置类的注册方式即可完成从配置文件读取配置信息

public class OrderService : IOrderService
{
    IOptions<OrderOptions> options;
    public OrderService(IOptions<OrderOptions> options)
    {
        this.options = options;
    }
    public void ShowMaxOrderCount()
    {
        Console.WriteLine($"MaxOrderCount:{options.Value.MaxOrderCount}");
        Console.WriteLine($"TotalOrderCount:{options.Value.TotalCount}");
    }
}
//注册方式
services.Configure<OrderOptions>(Configuration.GetSection("MaxOrderCount"));
services.AddSingleton<IOrderService, OrderService>();

通过这种方式,我们即可完成服务组件的配置集成。

和之前一样,我们仍然对注册方式进行封装,用扩展方法的方式来表示

public static class OrderServiceExtension
{
    public static IServiceCollection AddOrderService(this IServiceCollection services,IConfiguration configuration)
    {
        services.Configure<OrderOptions>(configuration);
        services.AddSingleton<IOrderService, OrderService>();
        return services;
    }
}

那么,使用选项框架时,我们如何来获取配置变更呢?

配置变更

首先,我们可定要定义ChangeToken.OnChange方法

ChangeToken.OnChange(() => Configuration.GetReloadToken(), () =>
{
    Console.WriteLine("重新加载配置");
});

对于选项框架的配置变更,我们有2种方式

  • IOptionsSnapshot:针对scope模式
  • IOptionsMonitor:针对单例模式,但也可用于scope模式

下面我们来说一下这两种方式的区别

IOptionsSnapshot

使用该方式时,只需修改服务中对应的配置类类型为IOptionsSnapshot<>。

public class OrderService : IOrderService
{
   IOptionsSnapshot<OrderOptions> optionsSnapshot;
   public OrderService(IOptionsSnapshot<OrderOptions> optionsSnapshot)
   {
       this.optionsSnapshot = optionsSnapshot;
   }
   public void ShowMaxOrderCount()
   {
       Console.WriteLine($"MaxOrderCount:{optionsSnapshot.Value.MaxOrderCount}");
   }
}

那么,我们在每次请求时,都会获取到新的配置值(这里可以使用刷新模拟重新请求)

IOptionsMonitor

同样的,使用该方式时,我们需要更改配置类型为IOptionsMonitor<>

public class OrderService : IOrderService
{
   IOptionsMonitor<OrderOptions> optionsMonitor;
   public OrderService(IOptionsMonitor<OrderOptions> optionsMonitor)
   {
       this.optionsMonitor= optionsMonitor;
       optionsMonitor.OnChange(options =>
            {
                Console.WriteLine($"配置发生了变更,新值为{optionsMonitor.CurrentValue.MaxOrderCount}");
            });
   }
   public void ShowMaxOrderCount()
   {
       Console.WriteLine($"MaxOrderCount:{optionsSnapshot.Value.MaxOrderCount}");
   }
}

IOptionsMonitor有一个OnChange方法可用于监听配置的变化,我们可用该方法来获取变更,并对变更后的值进行操作。

其实,如果只是获取监听,ChangeToken.OnChange仍然有效,区别在于,在配置框架中可以对配置的值进行操作。

 

PostConfigure

PostConfigure可以对配置进行操作并提交其修改,适用于,当取出配置后,需要对配置进行操作后在使用的情况,如下

public static class OrderServiceExtension
{
    public static IServiceCollection AddOrderService(this IServiceCollection services,IConfiguration configuration)
    {
        services.Configure<OrderOptions>(configuration);
        services.AddSingleton<IOrderService, OrderService>();
        //对配置+10
        services.PostConfigure<OrderOptions>(options => { options.MaxOrderCount += 10; });
        return services;
    }
}

好了,本篇到这里就结束了。下一篇学习选项框架中数据验证的3种方式。

源码可访问

https://github.com/IronMarmot/Samples/tree/master/CoreSamples


相关文章
|
1月前
|
设计模式 开发框架 JavaScript
基于.NET8 + Vue/UniApp前后端分离的快速开发框架,开箱即用!
基于.NET8 + Vue/UniApp前后端分离的快速开发框架,开箱即用!
|
2月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
170 3
|
20天前
|
消息中间件 开发框架 监控
NET任务调度框架Hangfire使用指南
Hangfire 是一个用于 .NET 应用程序的开源任务调度框架,支持长时间运行任务、定时任务等。通过简单的安装配置,即可将任务从主线程分离,提升应用性能。支持多种数据库,提供丰富的任务类型如立即执行、延迟执行和周期性任务,并有可视化管理界面 Hangfire Dashboard。还支持安全性配置及扩展插件,如 Hangfire.HttpJob,适合各种复杂场景下的任务调度需求。
44 1
NET任务调度框架Hangfire使用指南
|
1天前
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
|
1月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
41 2
|
1月前
|
开发框架 安全 .NET
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱。它不仅加速了应用开发进程,提升了开发质量和可靠性,还促进了创新和业务发展,培养了专业人才和技术社区,为软件开发和数字化转型做出了重要贡献。
30 5
|
1月前
|
传感器 人工智能 供应链
.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。
本文深入探讨了.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。通过企业级应用、Web应用及移动应用的创新案例,展示了.NET在各领域的广泛应用和巨大潜力。展望未来,.NET将与新兴技术深度融合,拓展跨平台开发,推动云原生应用发展,持续创新。
43 4
|
1月前
|
开发框架 .NET C#
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位
.NET 技术凭借高效开发环境、强大框架支持及跨平台特性,在软件开发中占据重要地位。从企业应用到电子商务,再到移动开发,.NET 均展现出卓越性能,助力开发者提升效率与项目质量,推动行业持续发展。
35 4
|
1月前
|
消息中间件 监控 数据可视化
基于.NET开源、功能强大且灵活的工作流引擎框架
基于.NET开源、功能强大且灵活的工作流引擎框架
|
1月前
|
开发框架 网络协议 .NET
C#/.NET/.NET Core优秀项目和框架2024年10月简报
C#/.NET/.NET Core优秀项目和框架2024年10月简报

热门文章

最新文章