Serilog 生成 ES 格式的日志
- Serilog.AspNetCore
- Serilog.Formatting.Elasticsearch
- Serilog.Sinks.Async
public static string LogFilePath(string LogEvent) => $@"{AppContext.BaseDirectory}Log/{LogEvent}/log.log";
public class Program
{
public static IConfiguration Configuration { get; } = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json", optional: false, reloadOnChange: true)
.AddEnvironmentVariables()
.Build();
public static int Main(string[] args)
{
Log.Logger = new LoggerConfiguration().ReadFrom.Configuration(Configuration)
.MinimumLevel.Debug()
.Enrich.FromLogContext()
.WriteTo.Logger(i =>
{
i.Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Error)
.WriteTo.File(formatter: new ElasticsearchJsonFormatter(), SharedPath.LogFilePath("Error"), rollingInterval: RollingInterval.Day, fileSizeLimitBytes: 1024 * 1024 * 10, rollOnFileSizeLimit: true);
}).WriteTo.Logger(i =>
{
i.Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Information)
.WriteTo.File(formatter: new ElasticsearchJsonFormatter(), SharedPath.LogFilePath("Information"), rollingInterval: RollingInterval.Day, fileSizeLimitBytes: 1024 * 1024 * 10, rollOnFileSizeLimit: true);
})
.WriteTo.Logger(i =>
{
i.Filter.ByIncludingOnly(e => e.Level == LogEventLevel.Warning)
.WriteTo.File(formatter: new ElasticsearchJsonFormatter(), SharedPath.LogFilePath("Warning"), rollingInterval: RollingInterval.Day, fileSizeLimitBytes: 1024 * 1024 * 10, rollOnFileSizeLimit: true);
})
.WriteTo.Console(new ElasticsearchJsonFormatter())
.CreateLogger();
try
{
Log.Information("Starting web host");
CreateHostBuilder(args).Build().Run();
return 0;
}
catch (Exception ex)
{
Log.Fatal(ex, "Host terminated unexpectedly");
return 1;
}
finally
{
Log.CloseAndFlush();
}
}
public static IHostBuilder CreateHostBuilder(string[] args) =>
Host.CreateDefaultBuilder(args)
.ConfigureWebHostDefaults(webBuilder =>
{
webBuilder.UseStartup<Startup>();
}).UseSerilog(dispose: true);
}