正确地将配置注入 ASP Core

Inject configuration into ASP Core correctly

我们在服务结构实例中托管了一个 ASP 核心网络 api。我想将所有配置转发到核心应用程序。我用这个方法

https://dzimchuk.net/configuring-asp-net-core-applications-in-service-fabric/

然后我使用 ConfigureAppConfiguration

调用它
protected override IEnumerable<ServiceInstanceListener> CreateServiceInstanceListeners()
{
    return new[]
    {
        new ServiceInstanceListener(serviceContext =>
            new KestrelCommunicationListener(serviceContext, "ServiceEndpoint", (url, listener) =>
            {
                ServiceEventSource.Current.ServiceMessage(serviceContext, $"Starting Kestrel on {url}");

                return new WebHostBuilder()
                            .UseKestrel()
                            .ConfigureServices(
                                services => services.AddSingleton(serviceContext))
                            .ConfigureAppConfiguration(builder => builder.AddServiceFabricConfiguration(serviceContext))
                            .UseContentRoot(Directory.GetCurrentDirectory())
                            .UseStartup<Startup>()
                            .UseServiceFabricIntegration(listener, ServiceFabricIntegrationOptions.UseReverseProxyIntegration)
                            .UseUrls(url)
                            .Build();
            }))
    };
}

启动时受感染的配置 class 确实应用了配置,例如连接字符串和日志记录

但它似乎没有完全嵌入到框架中。

例如,我需要使用配置 services.AddApplicationInsightsTelemetry(Configuration); 显式提供 ApplicationInsights,否则它不会获取工具密钥。并且日志记录不起作用(未应用日志级别)。

更新:

我尝试在没有服务结构的标准核心项目中做一个自定义配置提供程序,它工作正常。

public class Program
{
    public static void Main(string[] args)
    {
        CreateWebHostBuilder(args).Build().Run();
    }

    public static IWebHostBuilder CreateWebHostBuilder(string[] args) =>
        WebHost.CreateDefaultBuilder(args)
            .ConfigureAppConfiguration(builder => builder.AddServiceFabricConfiguration())
            .UseStartup<Startup>();
}

internal class ServiceFabricConfigurationProvider : ConfigurationProvider
{

    public override void Load()
    {
        Data["Logging:Debug:LogLevel:Default"] = "Information";
    }
}

internal class ServiceFabricConfigurationSource : IConfigurationSource
{


    public IConfigurationProvider Build(IConfigurationBuilder builder)
    {
        return new ServiceFabricConfigurationProvider();
    }
}

public static class ServiceFabricConfigurationExtensions
{
    public static IConfigurationBuilder AddServiceFabricConfiguration(this IConfigurationBuilder builder)
    {
        builder.Add(new ServiceFabricConfigurationSource());
        return builder;
    }
}

看来我为 fabric land 服务的东西没有正常工作。

编辑:复制项目 https://github.com/AndersMalmgren/ServiceFabricLoggingRepro

Service Fabric 项目模板与标准核心项目不同。

Service Fabric 项目模板可以

return new WebHostBuilder()

标准核心项目模板可以

WebHost.CreateDefaultBuilder(args)

我建议微软统一他们的项目模板 https://github.com/microsoft/service-fabric/issues/319#issuecomment-486116026

上面我也提到了Application insights。它没有直接关系。 Application insights 不注入 IConfiguration,而是查找 json 文件。我会说这是一个错误,但修复它会是一个重大更改

https://github.com/microsoft/ApplicationInsights-aspnetcore/issues/867