【问题标题】:'Serilog.Extensions.Hosting.DiagnosticContext' while attempting to activate 'Serilog.AspNetCore.RequestLoggingMiddleware'尝试激活“Serilog.AspNetCore.RequestLoggingMiddleware”时的“Serilog.Extensions.Hosting.DiagnosticContext”
【发布时间】:2022-03-23 03:36:50
【问题描述】:

当我运行我的程序直到启动 > 配置时,它可以在 C:\Serilog 创建日志文本文件,但它会在下面的这一行中断:

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
            
        });

错误是:

Microsoft.AspNetCore.Hosting.Diagnostics[6]
      Application startup exception
System.InvalidOperationException: Unable to resolve service for type 'Serilog.Extensions.Hosting.DiagnosticContext' while attempting to activate 'Serilog.AspNetCore.RequestLoggingMiddleware'

这是我的程序.cs:

using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.Hosting;
using Serilog;
using System;

namespace xxx
{
    public class Program
    {
        public static void Main(string[] args)
        {
           
            var configuration = new ConfigurationBuilder().AddJsonFile("appsettings.json").Build();

            Log.Logger = new LoggerConfiguration().ReadFrom.Configuration(configuration).CreateLogger();

            try
            {
                Log.Information("Application starting up");
                CreateHostBuilder(args).Build().Run();
            }
            catch (Exception ex)
            {
                Log.Fatal(ex, "The application failed to start correctly.");
            }
            finally
            {
                Log.CloseAndFlush();
            }
        }

        public static IHostBuilder CreateHostBuilder(string[] args) =>
            Host.CreateDefaultBuilder(args)
                .ConfigureWebHostDefaults(webBuilder =>
                {
                    webBuilder.UseStartup<Startup>();
                });
    }
}

这是我的 startup.cs

using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Microsoft.OpenApi.Models;
using Serilog;

namespace xxx
{
    public class Startup
    {
        public Startup(IConfiguration configuration)
        {
            Configuration = configuration;
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddControllers();
        }

        // This method gets called by the runtime. Use this method to configure the HTTP request pipeline.
        public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
        {
            if (env.IsDevelopment())
            {
                app.UseDeveloperExceptionPage();
            }

            app.UseHttpsRedirection();

            app.UseSerilogRequestLogging();

            app.UseRouting();

            app.UseAuthorization();

            app.UseEndpoints(endpoints =>
            {
                endpoints.MapControllers();
                
            });

        }
    }
}

还有我的 appsettings.json

{
  "Logging": {
    "LogLevel": {
      "Default": "Information",
      "Microsoft": "Warning",
      "Microsoft.Hosting.Lifetime": "Information"
    }
  },
  "AllowedHosts": "*",
  "Serilog": {
    "Using": [],
    "MinimumLevel": {
      "Default": "Warning",
      "Override": {
        "Microsoft": "Warning",
        "System": "Warning"
      }
    },
    "Enrich": [ "FromLogContext", "WithMachineName", "WithProcessId", "WithThreadId" ],
    "WriteTo": [
      { "Name": "Console" },
      {
        "Name": "File",
        "Args": {
          "path": "C:\\SeriLog\\log.txt",
          "outputTemplate": "{Timestamp:G} {Message}{NewLine:1}{Exception:1}}"
        }
      },
      {
        "Name": "File",
        "Args": {
          "path": "C:\\SeriLog\\log.json",
          "formatter": "Serilog.Formatting.Json.JsonFormatter, Serilog"
        }
      },
      {
        "Name": "Seq",
        "Args": {
          "serverUrl": "http://localhost:8081"
        }
      }
    ]
  }
}

【问题讨论】:

    标签: c#


    【解决方案1】:

    您似乎在Program 中缺少.UseSerilog。这是我的Program 模板:

    public class Program
    {
        public static void Main(string[] args)
        {
            var webHost = CreateHostBuilder(args)
                .Build();
    
            // access any service from here by using webHost.Services.GetService<...
            
            Log.Information("Starting MyWebApp");
    
            // ... configure Serilog
    
            try
            {
              webHost.Run();
            }
            catch (Exception ex)
            {
              Log.Fatal(ex, "The application failed to start correctly.");
            }
            finally
            {
              Log.CloseAndFlush();
            }
        }
    
        public static IHostBuilder CreateHostBuilder(string[] args) =>
            Host.CreateDefaultBuilder(args)
                .ConfigureWebHostDefaults(webBuilder =>
                {
                    webBuilder.UseStartup<Startup>();
                })
                .UseSerilog();
    }
    

    【讨论】:

      【解决方案2】:

      Upd 2022 在 .Net 6 中,当您没有 Startup 和 Main 类时,它可以在 program.cs 中使用,例如:

      try
      {
          var builder = WebApplication.CreateBuilder(args);
          var logger = new LoggerConfiguration()
                              .ReadFrom.Configuration(builder.Configuration)
                              .Enrich.FromLogContext()
                              .CreateLogger();
          builder.Host.UseSerilog(logger);
      
          // more configuration
      
          var app = builder.Build();
          app.UseSerilogRequestLogging();
      
          // more configs
          app.Run();
      }
      catch (Exception ex)
      {
          Log.Fatal(ex, "Unhandled exception");
      }
      finally
      {
          Log.Information("Shut down complete");
          Log.CloseAndFlush();
      } 
      
      

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2013-11-28
        • 2020-02-09
        • 1970-01-01
        • 2020-05-24
        • 2018-04-06
        • 2021-08-25
        • 1970-01-01
        相关资源
        最近更新 更多