log4net:肢解异常

发布于 2024-11-28 05:39:27 字数 864 浏览 2 评论 0原文

我想将异常的堆栈跟踪与其消息分开。例如在这个例子中:

System.NullReferenceException:未将对象引用设置到实例 一个对象的。
在 BetweenSvc.Bettweensvc.processRequest(RequestManagerRepository rmr, 请求对话 rc) 中 C:\Repository\bettween\trunk\Solution\BettweenSvc\Bettweensvc.cs:line 277
在 BettweenSvc.Bettweensvc.bettweenTimer_Elapsed(对象 发送者、ElapsedEventArgs e) 中 C:\Repository\bettween\trunk\Solution\BettweenSvc\Bettweensvc.cs:line 111

我要登录

System.NullReferenceException:未将对象引用设置到实例 一个物体的。

在一个字段中,其余字段在另一个字段中

目前我

<parameter>
  <parameterName value="@exception" />
  <dbType value="String" />
  <size value="2000" />
  <layout type="log4net.Layout.ExceptionLayout" />
</parameter>

在 AdoNetAppender 中,我将如何执行此操作?

I want to separate exception's stack trace from their message. for instance in this example:

System.NullReferenceException: Object reference not set to an instance
of an object.
at
BettweenSvc.Bettweensvc.processRequest(RequestManagerRepository rmr,
RequestConversation rc) in
C:\Repository\bettween\trunk\Solution\BettweenSvc\Bettweensvc.cs:line
277
at BettweenSvc.Bettweensvc.bettweenTimer_Elapsed(Object
sender, ElapsedEventArgs e) in
C:\Repository\bettween\trunk\Solution\BettweenSvc\Bettweensvc.cs:line
111

I want to log

System.NullReferenceException: Object reference not set to an instance
of an object.

in one field and the rest in another

Currently I have

<parameter>
  <parameterName value="@exception" />
  <dbType value="String" />
  <size value="2000" />
  <layout type="log4net.Layout.ExceptionLayout" />
</parameter>

in my AdoNetAppender, how would I do this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

勿忘心安 2024-12-05 05:39:27

这应该可行:

<parameter>
  <parameterName value="@exception" />
  <dbType value="String" />
  <size value="2000" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%exception{message}" />
  </layout>
</parameter>

如果您想要堆栈跟踪,请使用 %exception{stacktrace}

编辑
如果您使用的是 log4net 1.2.10,那么您需要实现自己的模式布局来完成您想要的操作。我建议检查当前的 log4net 源代码(主干),看看他们是如何做到这一点的(实际上非​​常简单)。 这里是此类布局转换器的示例。

This should work:

<parameter>
  <parameterName value="@exception" />
  <dbType value="String" />
  <size value="2000" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%exception{message}" />
  </layout>
</parameter>

If you want the stacktrace you use %exception{stacktrace}.

EDIT:
If you are using log4net 1.2.10 then you need to implement your own pattern layout that does what you want. I recommend to check the current log4net source code (trunk) to see how they do it (it is quite simple really). Here is an example of such a layout converter.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文