【发布时间】:2020-04-08 14:56:27
【问题描述】:
我正在测试新的structured logging,但并没有真正做到正确。
我的 nlog.config 中有这个:
<target xsi:type="File" name="f" fileName="${basedir}/logs/${shortdate}.log">
<layout xsi:type="JsonLayout" includeAllProperties="true">${longdate}|${level}|${logger}|${message}</layout>
</target>
<logger name="CommunicationLogger" minlevel="Info" writeto="f"></logger>
我的日志代码如下所示:
public void LogCommunication(string operation, List<object> args)
{
var parameters = new List<object>();
var text = "Operation:{Operation} ";
parameters.Add(operation);
text += "PersonId:{PersonId} ";
parameters.Add(SharedContext.GetMyUserContext().CurrentPersonId);
text += "ClientMachineName:{ComputerName} ";
parameters.Add(SharedContext.GetMyUserContext().ClientMachineName);
text += "Servername:{MachineName} ";
parameters.Add(Environment.MachineName);
if (args != null)
{
foreach(var param in args)
{
text += "Param:{@Parameters} ";
parameters.Add(param);
}
}
_log.LogCommunication(text, parameters.ToArray());
}
public void LogCommunication(string message, params object[] args)
{
_comLogger.Log(LogLevel.Info, message, args);
}
输出看起来像这样:
{ "Operation": "OperationName", "PersonId": 1, "ComputerName": “我的计算机名”、“机器名”:“我的机器名”、“参数”: {"LocationKeyList":[], "MyObjectIdList":[], "RolList":[]} }
我希望参数也得到序列化,而不是仅仅 showint [],这样我就可以看到服务操作的所有参数。参数是带有dataContract(WCF)的复杂类型。
有没有一种简单的方法可以让参数与结构数据一起使用。
推荐
更新1
nlog.config
<target xsi:type="File" name="f" fileName="${basedir}/logs/${shortdate}.log">
<layout xsi:type="JsonLayout" includeAllProperties="true" maxRecursionLimit="10">
<attribute name="time" layout="${longdate}" />
<attribute name="level" layout="${level}"/>
<attribute name="message" layout="${message}" />
</layout>
</target>
设置数据的代码
var parameters = new List<object>();
var text = "{TimeStamp} - ";
parameters.Add(DateTime.Now);
text += "Duration:{Duration} ";
parameters.Add(Timestamp);
text += "Operation:{Operation} ";
parameters.Add(operation);
text += "PersonId:{PersonId} ";
parameters.Add(SharedContext.GetMyUserContext().CurrentPersonId);
text += "ClientMachineName:{ComputerName} ";
parameters.Add(SharedContext.GetMyUserContext().ClientMachineName);
text += "Servername:{MachineName} ";
parameters.Add(Environment.MachineName);
if (args != null && args.Count() > 0)
{
text += "Param:{@Parameters} ";
parameters.Add(args);
}
_log.LogCommunication(text, parameters.ToArray());
结果:
ientMachineName:\"MyComputer\" 服务器名:\"MyComputer\" 参数:[\"MyApp.ServiceContracts.GetEntityViewRequest\"] ", “时间戳”:“2020-04-08T23:30:59.7725147Z”,“持续时间”: “00:00:00.0009930”,“操作”:“GetReferenceData”,“PersonId”:1, “计算机名”:“SE-MyCom”,“机器名”:“SE-MyCom”, “参数”:[“MyApp.ServiceContracts.GetEntityViewRequest”] }
{ “时间”:“2020-04-09 01:31:00.3637”,“级别”:“信息”,“消息”: “2020-04-09 01:31:00 - 持续时间:00:00:00.5594936 操作:\"GetExternaAnrop\" PersonId:1 ClientMachineName:\"MyComputer\" 服务器名:\"MyComputer\" 参数:[{\"PlaceringKeyList\":[], \"ArbetsstalleIdList\":[], \"RollList\":[]}]", "时间戳": "2020-04-08T23:31:00.363752Z", “持续时间”:“00:00:00.5594936”,“操作”:“GetExternaAnrop”, “PersonId”:1,“计算机名”:“SE-MyCom”,“机器名”: “SE-MyCom”,“参数”:[{“PlaceringKeyList”:[], "ArbetsstalleIdList":[], "RollList":[]}] }
更新2
我有一个如下所示的服务方法:
GetEntityViewResponse GetReferenceData(GetEntityViewRequest request);
请求类如下所示:
[DataContract]
public class GetEntityViewRequest
{
public GetEntityViewRequest(params EntityViewKey[] Keys)
{
EntityViewKeys.AddRange(Keys);
}
public GetEntityViewRequest(params int[] EgnaKodtyper)
{
MyList.AddRange(EgnaKodtyper);
}
public GetEntityViewRequest()
{
}
[DataMember]
public List<EntityViewKey> EntityViewKeys = new List<EntityViewKey>();
[DataMember]
public List<int> MyList= new List<int>();
}
运行代码(发送请求)时,我可以在服务端的 messageInspector 中看到我获得了数据。 EntityViewKeys 有一个枚举集。
NLog 输出如下所示:
{ “时间”:“2020-04-12 19:27:55.6690”,“级别”:“信息”,“消息”: “2020-04-12 19:27:55 - 持续时间:00:00:00.0034730 操作:\"GetReferenceData\" PersonId:1 ClientMachineName:\"MyComputer\" 服务器名:\"MyComputer\" 参数:[\"Orbit.ServiceContracts.GetEntityViewRequest\"]", “时间戳”:“2020-04-12T17:27:55.6690745Z”,“持续时间”: “00:00:00.0034730”,“操作”:“GetReferenceData”,“PersonId”:1, “计算机名”:“SE-MyCom”,“机器名”:“SE-MyCom”, “参数”:[“Orbit.ServiceContracts.GetEntityViewRequest”] }
所以即使这个类并不复杂,它仍然不会在 NLog 中打印内容?
【问题讨论】:
标签: c# .net data-structures config nlog