当前位置: 首页 > 面试题库 >

日志记录和依赖注入

蓝夕
2023-03-14
问题内容

我尝试构建基于Java的应用程序。

对于依赖项注入,我使用Google Guice。

现在我想到了在应用程序中记录一些信息的问题。我不是在谈论方法调用等方式的常规日志记录。我对AOP有所了解,并且我可以像这样进行方法调用跟踪。

我要寻找的是手动记录。我需要某种方式登录应用程序中的几乎每个类。所以我考虑了两个选择:

  1. 通过使用Guice注入框架通过构造函数(或setter或private …)为我做到这一点,从而获得记录器,但是感觉就像真的将日志记录问题添加到每个类并污染了我的构造器
  2. 在我要调用日志的方法中使用全局服务定位器。嗯,但是所有DI粉丝都会讨厌我这样做

那么从实际角度来看最好的方法是什么?


问题答案:

我需要某种方式登录应用程序中的几乎每个类。

再想一想。如果您认为几乎每个类都需要登录,则您的设计有问题。这个Stackoverflow答案讨论您的设计可能出什么问题。它是在.NET上下文中回答的,但答案也适用于Java。

该答案主要是关于异常日志记录的,对于非html" target="_blank">异常日志记录,我会说:防止在太多地方记录太多信息。对于您要记录的每个信息或警告,首先要问这是否应该不是例外。例如,不要记录“我们不应该在此分支中”之类的日志,而要抛出异常!

甚至当您要记录调试信息时,有没有人会阅读此信息?您最终将获得包含成千上万行的日志文件,没人会读取。而且,如果他们阅读了该文本,则必须遍历所有这些文本行,并对其进行复杂的正则表达式搜索,以获取所需的信息。

我看到开发人员这样做的另一个原因是掩盖他们的错误代码。就像以这种方式使用注释一样。我看到开发人员记录了诸如“我们已经执行了此块”或“如果跳过了分支这一点”之类的事情。这样,他们就可以遍历代码和大型方法。

但是,我们现在都知道写方法应该很小,而不是编写大方法。不,甚至更小。此外,如果您对代码进行彻底的单元测试,则没有太多理由调试代码,并且您已验证它可以执行预期的工作。

好的设计可以再次为您提供帮助。当您使用该Stackoverflow答案(带有命令处理程序)中所述的设计时,您可以再次创建一个装饰器,该装饰器可以序列化任意命令消息并将其记录在执行开始之前的磁盘上。这为您提供了非常准确的日志。只需在日志中添加一些上下文信息(例如执行时间和用户名),您就会拥有一个审计跟踪,甚至可以在调试甚至负载测试期间重播命令。

我使用这种类型的应用程序设计已有两年了,从那时起,我几乎没有理由在业务逻辑中进行额外的日志记录。有时需要它,但是这些情况很少见。

但是感觉就像真的在每个类中增加了日志记录关注,并且污染了我的构造函数

确实如此,您最终将获得带有太多参数的构造函数。但是不要怪记录器,也不要怪您的代码。您在这里违反了“
单一责任原则”。您可以通过静态外观调用此依赖项,以“隐藏”此依赖项,但这不会降低依赖项的数量和类的整体复杂性。

在我要调用日志的方法中使用全局服务定位器。嗯,但是所有DI粉丝都会讨厌我这样做

最后,您会为此而讨厌自己,因为每个类仍然有一个额外的依赖项(在这种情况下,这是一个隐蔽的依赖项)。这会使每个类变得更加复杂,并且将迫使您拥有更多的代码:要测试的代码更多,要有错误的代码更多,要维护的代码更多。



 类似资料:
  • 但是,部署在同一台服务器上的一些其他项目使用Tomcat的lib目录中存在的slf4j和log4j库,我无法删除这些库。 Tomcat lib目录中存在的Slf4J和Log4J版本 SLF4J-API-1.4.2 当我从Tomcat的lib目录中删除这些库并使用project的pom中提到的库时,我的项目运行良好 当我注释项目的pom文件中的依赖项并使用下面Tomcat的lib中的依赖项时,会引发

  • 我使用本教程使用SLF4J设置log4j2。这是我的全部pom.xml:

  • 我想在我的应用程序中使用SLF4J+logback用于两个目的--日志和审计。 14:41:57.978[main]信息AUDIT_LOGGER-110欢迎使用main 如何确保审核消息在审核记录器下只出现一次?

  • 问题内容: 我正在考虑将Redis用于Web应用程序日志记录目的。我用谷歌搜索,有人将日志转储到Redis队列/列表中,然后将计划的工作人员转储到磁盘中。 http://nosql.mypopescu.com/post/8652869828/another-redis-use-case- centralized-logging 我希望寻求理解,为什么不直接使用Redis持久化到磁盘?如果我分配了一

  • logging 模块自 2.3 版以来一直是 Python 标准库的一部分。在 PEP 282 中有对它的简洁描述。除了 基础日志教程 之外,这些文档是非常难以阅读的。 日志记录一般有两个目的: 诊断日志 记录与应用程序操作相关的日志。例如,当用户遇到程序报错时, 可通过搜索诊断日志以获得上下文信息。 审计日志 为商业分析而记录的日志。从审计日志中,可提取用户的交易信息, 并结合其他用户资料构成用

  • 问题内容: 我想使用PySide创建一个简单的应用程序,仅用于从python日志记录中输出。 我想知道: 如何重定向stdout写入QTextEdit? 如何编写logging.Handler记录到QTextEdit? 谢谢 问题答案: 这是从PyQt邮件列表复制粘贴的,但应该适用于PySide 这应该做您想要的。 用法示例: