刚开始使用 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);
}
编辑:
使用的水槽:
最佳答案
如果您知道 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/