.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


相关文章
|
6月前
|
数据可视化 Java BI
将 Spring 微服务与 BI 工具集成:最佳实践
本文探讨了 Spring 微服务与商业智能(BI)工具集成的潜力与实践。随着微服务架构和数据分析需求的增长,Spring Boot 和 Spring Cloud 提供了构建可扩展、弹性服务的框架,而 BI 工具则增强了数据可视化与实时分析能力。文章介绍了 Spring 微服务的核心概念、BI 工具在企业中的作用,并深入分析了两者集成带来的优势,如实时数据处理、个性化报告、数据聚合与安全保障。同时,文中还总结了集成过程中的最佳实践,包括事件驱动架构、集中配置管理、数据安全控制、模块化设计与持续优化策略,旨在帮助企业构建高效、智能的数据驱动系统。
329 1
将 Spring 微服务与 BI 工具集成:最佳实践
|
5月前
|
存储 Prometheus 监控
136_生产监控:Prometheus集成 - 设置警报与指标选择与LLM部署监控最佳实践
在大语言模型(LLM)部署的生产环境中,有效的监控系统是确保服务稳定性、可靠性和性能的关键。随着LLM模型规模的不断扩大和应用场景的日益复杂,传统的监控手段已难以满足需求。Prometheus作为当前最流行的开源监控系统之一,凭借其强大的时序数据收集、查询和告警能力,已成为LLM部署监控的首选工具。
|
6月前
|
人工智能 安全 API
Dify平台集成安全护栏最佳实践
Dify平台提供低代码构建AI大模型应用的解决方案,支持云服务与私有化部署。本文介绍了在工作流和Agent中集成安全护栏的最佳实践,包括插件和扩展API两种方案。插件方式适用于工作流,一键安装实现输入输出防控;扩展API方式适用于Agent和工作流私有化部署场景,通过本地服务适配安全护栏API。文中还详细说明了操作步骤、前提条件及常见问题处理方法,帮助用户快速实现内容安全控制。
|
11月前
|
中间件 Go
Golang | Gin:net/http与Gin启动web服务的简单比较
总的来说,`net/http`和 `Gin`都是优秀的库,它们各有优缺点。你应该根据你的需求和经验来选择最适合你的工具。希望这个比较可以帮助你做出决策。
538 35
|
11月前
|
人工智能 运维 关系型数据库
云服务API与MCP深度集成,RDS MCP最佳实践
近日,阿里云数据库RDS发布开源RDS MCP Server,将复杂的技术操作转化为自然语言交互,实现"对话即运维"的流畅体验。通过将RDS OpenAPI能力封装为MCP协议工具,用户只需像聊天一样描述需求,即可完成数据库实例创建、性能调优、故障排查等专业操作。本文介绍了RDS MCP(Model Context Protocol)的最佳实践及其应用,0代码,两步即可轻松完成RDS实例选型与创建,快来体验!
云服务API与MCP深度集成,RDS MCP最佳实践
|
11月前
|
人工智能 API 开发工具
GitHub官方开源MCP服务!GitHub MCP Server:无缝集成GitHub API,实现Git流程完全自动化
GitHub MCP Server是基于Model Context Protocol的服务器工具,提供与GitHub API的无缝集成,支持自动化处理问题、Pull Request和仓库管理等功能。
2164 2
GitHub官方开源MCP服务!GitHub MCP Server:无缝集成GitHub API,实现Git流程完全自动化
|
9月前
|
存储 缓存
.NET 6中Startup.cs文件注入本地缓存策略与服务生命周期管理实践:AddTransient, AddScoped, AddSingleton。
记住,选择正确的服务生命周期并妥善管理它们是至关重要的,因为它们直接影响你的应用程序的性能和行为。就像一个成功的建筑工地,工具箱如果整理得当,工具选择和使用得当,工地的整体效率将会大大提高。
324 0
|
C# Android开发 iOS开发
2025年全面的.NET跨平台应用框架推荐
2025年全面的.NET跨平台应用框架推荐
661 23
|
机器学习/深度学习 人工智能 自然语言处理
Voice-Pro:开源AI音频处理工具,集成转录、翻译、TTS等一站式服务
Voice-Pro是一款开源的多功能音频处理工具,集成了语音转文字、文本转语音、实时翻译、YouTube视频下载和人声分离等多种功能。它支持超过100种语言,适用于教育、娱乐和商业等多个领域,为用户提供一站式的音频处理解决方案,极大地提高工作效率和音频处理的便捷性。
1356 10
Voice-Pro:开源AI音频处理工具,集成转录、翻译、TTS等一站式服务
|
消息中间件 开发框架 监控
NET任务调度框架Hangfire使用指南
Hangfire 是一个用于 .NET 应用程序的开源任务调度框架,支持长时间运行任务、定时任务等。通过简单的安装配置,即可将任务从主线程分离,提升应用性能。支持多种数据库,提供丰富的任务类型如立即执行、延迟执行和周期性任务,并有可视化管理界面 Hangfire Dashboard。还支持安全性配置及扩展插件,如 Hangfire.HttpJob,适合各种复杂场景下的任务调度需求。
1455 1
NET任务调度框架Hangfire使用指南