5

我有兴趣了解人们在使用 log4net 等记录器时在其应用程序中记录时实际捕获和使用的字段。

这可以从调试到测试再到生产,可以用于胖客户端应用程序,但我更多地考虑 Web 应用程序的语义(即 asp.net)。

此外,在 Web 的上下文中(以及在一定程度上对于胖客户端),我对人们如何为给定请求构建日志整体的层次结构以及如何识别单个请求等感兴趣。

干杯安东尼

以下是我到目前为止所拍摄的内容:

LogId、ServerName、ServerIP、ApplicationAbbrv、ApplicationVersion、ApplicationAppDomain、LogDateTime、LogTimeStamp、LogLogger、CodeType、CodeClass、CodeFile、CodeLocation、CodeMethod、CodeLine、CodeStackPosition、LogMessage、LogException、LogEntityOrigin、ContextSessionId、ContextUserName、ContextThread、ContextObjectPropertyData、ContextMachineId、ContextMachineIP

4

2 回答 2

2

为了为请求创建一个“交互堆栈”,我们在用户第一次访问应用程序时在 cookie 中为用户分配一个 sessionid(guid)。然后我们按 sessionid/datetime 排序,看看事件的顺序是什么。

我们经常记录的另一件事是用户试图操作(插入/删除/更新)的数据(减去 ssn 等敏感数据),因为数据质量似乎是错误的主要来源。

于 2008-10-23T00:56:19.800 回答
1

记录所有错误

记录为已处理但应记录的警告事件。

除此之外,您需要将多少细节记录为Info取决于您。您可以将每个进入/退出点记录为信息到方法。就我个人而言,我认为这是对开发人员没有信心的代码的过度杀伤和症状。我会记录处理过程中发生的所有“主要”操作。

于 2008-10-23T00:05:39.433 回答