ASP.NET Core - Serilog没有将日志保存到PostgreSQL中。
创始人
2024-09-14 12:00:49
0

要将日志保存到PostgreSQL中,您可以使用Serilog的PostgreSQL扩展库。下面是一个使用ASP.NET Core和Serilog将日志保存到PostgreSQL的示例代码:

  1. 首先,使用NuGet将以下包添加到您的项目中:
Serilog
Serilog.Sinks.Console
Serilog.Sinks.PostgreSQL
  1. Program.cs文件中,更新CreateHostBuilder方法以配置Serilog:
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Hosting;
using Serilog;

public class Program
{
    public static void Main(string[] args)
    {
        Log.Logger = new LoggerConfiguration()
            .WriteTo.Console()
            .WriteTo.PostgreSQL("your_connection_string", "your_table_name")
            .CreateLogger();

        CreateHostBuilder(args).Build().Run();
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args)
            .UseSerilog()
            .ConfigureWebHostDefaults(webBuilder =>
            {
                webBuilder.UseStartup();
            });
}
  1. appsettings.json文件中,添加PostgreSQL连接字符串:
{
  "ConnectionStrings": {
    "DefaultConnection": "your_connection_string"
  }
}
  1. Startup.cs文件中,将Serilog添加到日志服务:
using Microsoft.AspNetCore.Builder;
using Microsoft.AspNetCore.Hosting;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
using Serilog;

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

    public IConfiguration Configuration { get; }

    public void ConfigureServices(IServiceCollection services)
    {
        services.AddControllers();

        // 添加日志服务
        services.AddLogging(loggingBuilder =>
        {
            loggingBuilder.ClearProviders();
            loggingBuilder.AddSerilog();
        });
    }

    public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
    {
        if (env.IsDevelopment())
        {
            app.UseDeveloperExceptionPage();
        }

        app.UseRouting();

        app.UseEndpoints(endpoints =>
        {
            endpoints.MapControllers();
        });
    }
}
  1. 现在,您可以在您的应用程序中使用ILogger接口来记录日志。例如,在控制器中:
using Microsoft.AspNetCore.Mvc;
using Microsoft.Extensions.Logging;

[ApiController]
[Route("[controller]")]
public class WeatherForecastController : ControllerBase
{
    private readonly ILogger _logger;

    public WeatherForecastController(ILogger logger)
    {
        _logger = logger;
    }

    [HttpGet]
    public IEnumerable Get()
    {
        _logger.LogInformation("Getting weather forecast");

        // ...其它代码...

        return weatherForecasts;
    }
}

请确保将your_connection_string替换为您的PostgreSQL连接字符串,your_table_name替换为您要保存日志的表名。

这样,您的日志将会保存到PostgreSQL中。

相关内容

热门资讯

透视教程!智星德州菠萝安装,w... 透视教程!智星德州菠萝安装,wepoker底牌透视脚本怎样安装,分享实测(有挂详情)智星德州菠萝辅助...
aapoker有外挂!aapo... aapoker有外挂!aapoker透明挂,(wopoker)一贯真的有挂,2025版教程(有挂插件...
透视攻略!wpk辅助器是真的吗... 透视攻略!wpk辅助器是真的吗,aapoker辅助器是真的吗,一分钟了解(有挂教程);小薇(透视辅助...
WePoKe外挂!wpk透视辅... WePoKe外挂!wpk透视辅助测试,(WEpoke)原来真的有挂,黑科技教程(有挂插件)该软件可以...
透视计算!hhpoker透视脚... 透视计算!hhpoker透视脚本安卓,wepoker辅助器怎么用,最新科技(有挂了解)1、每一步都需...
wepoke真的有挂!德州之星... wepoke真的有挂!德州之星外挂,(wepoKE)确实真的是有挂,细节方法(有挂细节)进入游戏-大...
透视透视!红龙poker透视工... 透视透视!红龙poker透视工具,德普之星透视辅助,发现一款(有挂规律)1、完成的残局,帮助玩家取得...
德州微扑克辅助!wpk真的有外... 德州微扑克辅助!wpk真的有外挂,(wepoKe)切实有挂,透明挂教程(有挂介绍)1、起透看视 德州...
透视系统!德普之星app安卓版... 透视系统!德普之星app安卓版破解版,wpk辅助插件叫什么,玩家必看攻略(有挂教程)辅助器中分为三种...
wpk透明挂!微扑克辅助器io... wpk透明挂!微扑克辅助器ios,(WepOke)竟然是真的有挂,安装教程(有挂教程);1、很好的工...