2

在 log4j.properties 文件中,我将 Level 设置为 ERROR。对于某些用户,我需要将 Level 设置为 DEBUG。我能够在运行时更改日志记录级别,但这将为同时访问应用程序的所有用户启用。是否有任何其他方法可以为选定用户启用日志记录?任何帮助将不胜感激。

4

3 回答 3

4

我想您有一个 Web 应用程序或类似的应用程序,并且有多个可识别的用户同时访问它?

您无法在 Log4j 中轻松更改每个用户的配置。但是我会考虑以下内容(这假设一个 Web 服务器或类似服务器,每个用户请求都在一个单独的线程上):

  1. 一旦用户进行了调用,就可以识别进行服务器调用的用户。将该用户数据存储在MDC中
  2. 实现自定义 Log4J appender。对于每个来电,您可以检查存储在 MDC 中的用户,并根据需要调整严重性/日志记录。

这是一点工作(鉴于上述假设),但应该工作。显然,如果我对您的架构所做的假设不正确,则它是无效的。

于 2009-05-21T13:02:09.110 回答
1

这个问题在 logback(log4j 的继任者)中用TurboFilters解决了。请参阅标题为“MDCFilter 和 MarkerFilter 配置”的示例。如果您需要进一步的帮助,请联系 logback-user 邮件列表。

于 2009-05-29T12:49:28.007 回答
0

对,但是。

您可以使用所涉及的类+用户来命名您的记录器,而不仅仅是类,并在方法上创建记录器(或者如果您想获得幻想,将记录器缓存在用户键入的某种池中),然后配置适当地记录。

它对代码非常混乱和侵入,但由于用户是运行时属性,我不知道如何(缺少 AspectJ 或其表亲)如何避免这种混乱。

另一种选择是专门格式化您的日志消息并在日志消息中包含用户名,然后解析日志。这将为每个人启用调试(显然这可能是一个性能问题),但如果更多关注的是隔离用户日志记录而不是限制调试调用的数量,那可能是一个解决方案。

于 2009-05-21T13:00:38.880 回答