使用 Serilog 接收器将日志发送到 DataDog 不起作用

问题描述 投票:0回答:2

背景:

我的设置:

  • 我有一个 DataDog 试用帐户

    enter image description here

  • 我在本地安装了 DataDog 代理,但我实际上想使用无代理方法将日志发送到 DataDog

    enter image description here

  • 我的记录器将日志记录到我的 Log/log.json 文件中,尽管它似乎不会立即更新文件,并且可能需要几分钟才能最终将信息放入文件中(不知道为什么)

    enter image description here

  • 我按照 Serilog 文档安装了以下依赖项:

    enter image description here

  • 我有一个 Angular 应用程序的 .Net 6 项目。

    enter image description here

  • 我有一个如下所示的appsettings.json:

      {
          "AllowedHosts": "*",
          "ConnectionStrings": {
              "SitePageToSitePageModernConnection": "Data Source=.\\SQLEXPRESS;Initial Catalog=Blah;Integrated Security=True;MultipleActiveResultSets=True;TrustServerCertificate=True"
          },
          "Serilog": {
              "Using": [
                  "Serilog.Sinks.File",
                  "Serilog.Sinks.Console",
                  "Serilog.Sinks.Datadog.Logs"
              ],
              "MinimumLevel": {
                  "Default": "Error",
                  "Override": {
                      "Microsoft": "Error",
                      "System": "Error",
                      "My.App.Namespace.Something": "Information"
                  }
              },
              "WriteTo": [
                  {
                      "Name": "File",
                      "Args": {
                          "path": "Logs/log.json",
                          "rollingInterval": "Day", // When a new file is created
                          "flushToDiskInterval": "00:00:01", // Currently does nothing. seems to be overwritten by operating system's paging cache interval (whatever that is)
                          "retainedFileCountLimit": 7 // How many files should be retained over the days specified by rollingInterval
                      }
                  },
                  {
                      "Name": "DatadogLogs",
                      "Args": {
                          "apiKey": "d7...b07",
                          "source": "something",
                          "host": "noideawhatgoeshere",
                          "configuration": {
                              "Url": "http-intake.logs.datadoghq.eu"
                          }
                      }
                  }
              ],
              "Enrich": [
                  "FromLogContext",
                  "WithMachineName",
                  "WithThreadId"
              ],
              "Properties": {
                  "Application": "MyApplicationSample"
              }
          }
      }
    
  • 我按以下方式设置 Serilog:

      // WebApplicationBuilder builder...
    
      builder.Services.AddLogging(loggingBuilder =>
      {
          ConfigurationManager configurationManager = builder.Configuration;
          Logger logger = new LoggerConfiguration()
              .ReadFrom
              .Configuration(configurationManager)
              .CreateLogger();
    
          // Adds serilog to the logging providers
          loggingBuilder.AddSerilog(logger);
      });
    

在控制器中,我使用

ILogger<MySiteController>
来记录。

    // constructor injects: 
    ...ILogger<MySiteController> _logger...

    // call to controller runs some logs:

    logger.LogInformation("Test information");
    logger.LogError("Test error");
    logger.LogWarning("Test warning");

我的疑问/问题:

  1. 我的日志最终都没有出现在 DataDog 中。我有什么遗漏或误解的想法吗?
c# serilog datadog
2个回答
5
投票

在本例中配置的 URL 不正确,应该是:

"configuration": {
     "url": "https://http-intake.logs.datadoghq.eu",
     "port": 443
}

有关更多信息,我提出了一些评论以帮助将来的其他人:

{
    // ...
    //"AllowedHosts": "*",
    // ...

    // Serilog framework can look at this to configure itself
    "Serilog": {

        // This determines which of the types of logging you want to have
        "Using": [

            // This is for logging into a file in a static manner
            "Serilog.Sinks.File",

            // This is for logging into a file that can be configured to log for a day and then create a new file at the next day (a rolling file, get it?)
            "Serilog.Sinks.RollingFile",

            // This will allow logs to go into your console. Console in this case (for an Angular driven app, means the Terminal that appears when you launch your app)
            "Serilog.Sinks.Console",

            // This will allow logging to Datadog
            "Serilog.Sinks.Datadog.Logs"
        ],

        // These are the log levels you want to support
        "MinimumLevel": {

            // By default, you could say "I only want to see errors coming up"
            "Default": "Error",

            // If you are wanting to see information or debug or trace etc logs from other specific c# class namespaces, then you can configure them here
            "Override": {

                // Anything in a namespace that starts with `Microsoft` we only care about Errors being flagged (for example)
                "Microsoft": "Error",

                // Anything in a namespace that starts with `System` we only care about Errors being flagged (for example)
                "System": "Error",

                // If you had a tool with a C# class's namespace of "My.Tooling.Test", you, in this case will probably want to see all the logs you raise. so we could set this to Information (for example)
                "My.Tooling.Test": "Information"
            }
        },

        // Given that we have defined which frameworks we want to make use of in the "Using" section, we can now use the framework functionality for Console, File, RollingFile, Datadog, etc.
        "WriteTo": [

            // Tells Serilog to log stuff to the console
            {
                "Name": "Console"
                //... You can configure more here but you'll need to Google that yourself
            },

            // Tells Serilog to log stuff to a File
            {
                "Name": "File",

                //... You can configure more here but you'll need to Google that yourself
                "Args": {
                    "path": "App_Data\\logs\\log.txt",
                    "rollingInterval": 3,
                    "outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss,fff} [P{ProcessId}/D%APP_DOMAIN_ID%/T{ThreadId}] {Level:u4} {CorrelationId} {UserId} - {Message:lj}{Exception}{NewLine}"
                }
            },

            // Tells Serilog to log stuff to a Rolling File
            {
                "Name": "RollingFile",

                //... You can configure more here but you'll need to Google that yourself.
                "Args": {
                    "path": "App_Data\\logs\\DiagnosticTraceLog.txt{RollingDate}",
                    "shared": true,
                    "outputTemplate": "{Timestamp:yyyy-MM-dd HH:mm:ss,fff} [P{ProcessId}/D%APP_DOMAIN_ID%/T{ThreadId}] {Level:u4} {CorrelationId} {UserId} - {Message:lj}{Exception}{NewLine}"
                }
            },

            // Tells Serilog to log stuff to a DataDog instance
            {
                // This name is important! It must be precisely this to work!
                "Name": "DatadogLogs",

                // The configuration properties here must all be written precisely as the following are
                "Args": {

                    // Mandatory | API Key - Found in Datadog Organization/Api Keys section.
                    "apiKey": "6c...91",

                    // Optional | An arbitrary "source" that enables you to filter to your logs within the DataDog application
                    "source": "anything.you.want",

                    // Optional | An arbitrary "servive" that enables you to filter to your logs within the DataDog application
                    "service": "anything.you.want",

                    // Optional | An arbitrary "host" that enables you to filter to your logs within the DataDog application
                    "host": "anything.you.want",

                    // Optional | Arbitrary "tags" that enables you to filter to your logs within the DataDog application
                    "tags": [ "app.name:My.Tooling.Test" ],

                    // Optional | The default Datadog server is "intake.logs.datadoghq.com". If your DataDog instance is on the "app.datadoghq.com" URL, you do not need any of this configuration.
                    //
                    //          | If you are not on the default Datadog server, you will need to find out what server you are on by visiting here and using the dropdown at the right https://docs.datadoghq.com/getting_started/site/
                    //          | and then, once you know the server, you can visit here for the URL to use: https://docs.datadoghq.com/logs/log_collection/?tab=host#supported-endpoints
                    // 
                    //          | IMPORTANT: the URLs are not quite the entire URL that's needed. Be aware that "https://" will need to be placed on to determine which type you want to use. For example:
                    "configuration": {
                        "url": "https://http-intake.logs.datadoghq.eu",
                        "port": 443
                    }
                }
            }
        ],

        // This ends up being stored in the final log message that is raised for you. You'll see it in DataDog under "properties" object where it mentions "Thread Id" or "SourceContext" for example.
        "Enrich": [ "FromLogContext", "WithMachineName", "WithThreadId" ],

        // This ends up being stored in the final log message that is raised for you. You'll see it in DataDog under "properties" object where it mentions "Application".
        "Properties": {
            "Application": "My.Tooling.Test"
        }
    }
}

特别是对于 C# 应用程序,需要安装以下软件包才能使用上述内容

appsettings.json
:

  • 必填事项:
    • microsoft.extensions.configuration.json
    • serilog.aspnetcore
  • Sink 类型(appsettings.json 中定义的用途):
    • serilog.sinks.datadog.logs
    • serilog.sinks.file
    • serilog.sinks.rollingfile
  • 您使用过的丰富工具:
    • serilog.enrichers.environment
    • serilog.enrichers.thread
    • serilog.settings.configuration
    • serilog.aspnetcore.enrichers.correlationid

这些都可以像这样在 C# 中配置(你有 2 个选择):

// This allows you to add a Logging Provider to the already filled out list of logging providers
// that are supplied by default to your application.
builder.Services.AddLogging(loggingBuilder =>
{
    // Get the builder's configuration from your Program 
    // (It essentially just gets the appsettings.json file)
    ConfigurationManager configurationManager = builder.Configuration;

    // Create a new LoggerConfiguration so that you can tell 
    // it to get its configuration from your appsettings.json file
    Logger logger = new LoggerConfiguration()
        .ReadFrom
        .Configuration(configurationManager)

        // Finally create the logger which will be used
        .CreateLogger();

    // Adds serilog to the logging providers
    loggingBuilder.AddSerilog(logger);
});

// Forces all logs to go through your single serilog configuration
// Be aware that if you use this, you need to ensure you configure your Serilog to
// do Console logging, otherwise you won't see any logs in the console.
// Luckily, I've provided all the code you need to do that in the appsettings.json configuration
// (But you may need to change the log level to Information or Debug for it to show up)
builder.Host.UseSerilog((hostingContext, services, loggerConfiguration) =>
{
   loggerConfiguration.ReadFrom.Configuration(hostingContext.Configuration);
});

最后,您可以通过将

ILogger<YOURCLASSNAME> logger
注入到要使用它的类中并运行以下命令来创建日志:

logger.LogInformation("{message}", "Test");
logger.LogWarning("{message}", "Test");
logger.LogError("{message} {exception}", "Test", error);
logger.LogWarning(JsonConvert.SerializeObject(new Something() { Name = "Something", Description = "Something" }));

0
投票

如果您在资源管理器仪表板中没有看到日志,请确保您指向正确的 Datadog site。就我而言,我错误地指向了默认 US1。

最新问题
© www.soinside.com 2019 - 2025. All rights reserved.