c# - 在 serilog 中使用 C# 参数

标签 c# elasticsearch parameters optional-parameters serilog

刚开始使用 Serilog + ElasticSearch 并想知道是否有一种优雅的方式来记录 params一个日志条目中的对象数组。到目前为止,我能够管理它的唯一方法是遍历每个 params它为每个人创建一个单独的日志条目。有什么办法可以将它们组合成一个日志条目?

谢谢!

样本:

public static void MethodEntry<T>(string methodName, params object[] parameters)
{
    if (parameters.Length > 0)
        foreach (var param in parameters) // Will create parameters.Length number of log entries
            Log.ForContext(typeof(T)).Debug("Entering {MethodName} with {@Param}", methodName, param);
    else
        Log.ForContext(typeof(T)).Debug("Entering {MethodName}", methodName);
}

编辑:

使用的水槽:
  • Serilog
  • Serilog.Sinks.Elasticsearch(包括文件、PeriodicBatching 和 RollingFile 接收器)
  • 像 Environment 和 ThreadId 这样的增强器
  • 最佳答案

    如果您知道 Sender 对象的特定类型,您可以使用 Serilog 的以下功能来避免记录不需要的信息:

    Log.Logger = new LoggerConfiguration()
        .Destructure.ByTransforming<YOUR_SENDER_TYPE>(
            r => new { firstValue = r.firstValue, secondValue = r.secondValue })
        .WriteTo .... 
    

    有关记录结构化数据的更多信息,您可以在官方文档 Serilog Structured Data 中找到

    关于c# - 在 serilog 中使用 C# 参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46163967/

    相关文章:

    c# - 如何检查关系是否已经存在?

    c++ - C/C++ 中数组的参数传递和作用域

    function - PowerShell 传递函数中接收到的所有参数,并处理带空格的参数

    c# - 在 Entity Framework 中处理主数据表和相关表

    c# - 在浏览器关闭中杀死 session 值

    c# - 将 VB.NET DLL 导入 C#.Net 项目

    c# - 如何为弹性条件源描述符创建Nest

    elasticsearch - 禁用_source时,可以提取not_analyzed字段的实际值吗?

    java - ElasticSearch 轮询不起作用

    c# - 如何使用 C# 集合初始值设定项调用方法?