- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想知道日志代码应该去哪里。例如,我的存储库应该记录它自己的错误吗?还是应该从UI /控制器记录所有错误?是否有关于此的一般设计原则,或者是否有人链接到好的文章或诸如此类的文章。
最佳答案
日志记录和跟踪是(IMO)的一种美术,它知道要记录什么以及在哪里需要经验。
我发现,学习测井技术的最好(最差?)方法是体验尝试诊断劣质测井问题的痛苦!
我只能为您提供一些建议:
考虑如何使用日志消息。
良好日志记录的关键是考虑问题时如何使用日志消息,相反,不良日志记录最糟糕的事情是,只有在遇到问题并且没有足够的信息时,您才会意识到这一点!
始终考虑日志消息对正在阅读的人说的是什么,例如:
Windows API调用失败了吗?如果是这样,那么您可能需要记录HRESULT
和GetLastError
结果(如果有的话),以使其有用。
在集合中找不到条目?如果没有找不到条目的名称,那么实际上没有人可以推断出太多的信息-知道集合的数量也很方便,这样您就可以知道该集合是否为空。
一个常见的错误是没有考虑日志记录时需要什么信息,但是您也应该仔细考虑何时记录一条消息-如果在正常操作下频繁记录一条消息,那么充其量是有用的,并且在最坏的情况下该日志是有用的信息可能会产生误导。
另外,请确保您可以识别记录消息的内容。如果您在日志中看到的只是一个字符串,该字符串多次出现在您的代码库中(或者更糟糕的是根本没有!),那么您将需要推论并想弄清楚该日志消息的来源(并且没有知道消息的来源,您几乎没有希望理解它)
在多线程/多处理器应用程序中,始终记录线程ID和进程ID。
如果您有任何类型的请求ID,请也进行记录。
如果您认为您将花费任何合理的时间来查看日志文件,那么您应该强烈考虑运送所需的任何pdb等...文件,以便查看源文件和行号。
仅在出现问题时使用日志记录
不要将日志记录与错误处理混淆。错误处理是响应并解决该错误的行为(例如向用户显示一条消息),(通常)仅在出现问题且原因不清楚时才使用日志。
例如:如果用户尝试打开一个不存在的文件,那么如果正确处理了错误(通过告诉用户找不到该文件),则无需记录该错误。
(可能的例外可能是,如果您想要统计该错误发生的频率或发生的某件事,那就是回想起日志的使用方式。)
通常,正确地处理错误比记录日志更可取,但是良好的错误处理要比良好的日志记录更加困难-在这种情况下,需要日志中提供的额外信息。
您也不应将日志记录与审计混淆(尽管在许多系统中两者是重叠的)。
多多益善!
记录过多日志的唯一方法是:
您的存储空间不足。
您会严重影响应用程序的性能。
您会遇到大量日志,这些日志在发生错误时无法轻松处理。
您记录对老板的亵渎。
日志记录纯粹是为了诊断问题的原因(不要将日志记录与审核混为一谈)-如果您没有任何问题,那么没人会看您的日志,并且不会造成任何危害!在出现问题之前,在这种情况下,您需要尽可能多的信息。
如果您不确定是否要记录某些内容,请对其进行记录。
仅记录一次异常。
综上所述,我认为有必要澄清异常的记录。
通常,您只应记录一次异常(在处理异常的地方)。不要试图记录一个异常,然后稍后将其抛出给调用方,以防万一调用方没有正确记录该异常-发生的所有事情是,您最终会多次记录相同的异常从一层到另一层(我已经看到了这种情况的发生,这使得很难看到实际发生了多少错误)。
记录错误是呼叫者的责任-唯一可能的异常可能是在系统边界(例如Web服务)之间传递,因此不可能在所有错误详细信息之间进行传输。
记录任何相关的内容,无论它记录在何处。
例如,如果您正在编写基于服务器的应用程序,则您的日志文件必须位于服务器上,系统管理员可以在其中读取它们-但是,如果在客户端上可能发生错误(例如JavaScript),则您的日志记录代码必须使用JavaScript。解决方案?您的JavaScript日志记录需要将自身提交到服务器(ala log4js)
不必担心您应该将日志记录在何处,不应该将日志记录在任何需要的地方。
关于design-patterns - 日志代码应该去哪/什么级别?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3658527/
Android 项目中最低(最低 sdk)和最高(目标 sdk)级别是否有任何影响。这些东西是否会影响项目的可靠性和效率。 最佳答案 没有影响,如果您以 SDK 级别 8 为目标,那么您的应用将以 9
我将现有的 android 项目升级到 API 级别 31。我使用 Java 作为语言。我改变了 build.gradle compileSdkVersion 31 defaultConfig {
我正在使用 ionic 3 创建一个 android 应用程序,当我尝试上传到 playstore 时,我收到一个错误,提示我的应用程序以 api 25 为目标,当我检查我的 project.prop
我刚刚尝试将应用程序的目标和编译 API 级别更新为 29 (Android 10),并注意到我无法再编译,因为 LocationManager.addNmeaListener 只接受 OnNmeaM
我的代码没有在 Kitkat 上显示工具栏。 这是我的两个 Android 版本的屏幕截图。 Kitkat 版本: Lollipop 版: 这背后的原因可能是什么。 list 文件
我正在构建面向 API 级别 8 的 AccessabilityService,但我想使用 API 级别 18 中引入的功能 (getViewIdResourceName())。这应该可以通过使用 A
当我想在我的电脑上创建一个 android 虚拟机时,有两个选项可以选择目标设备。它们都用于相同的 API 级别。那么我应该选择哪一个呢?它们之间有什么区别? 最佳答案 一个是基本的 Android,
当我选择 tagret 作为 Android 4.2.2(API 级别 17)时,模拟器需要很长时间来加载和启动。 所以我研究它并通过使用 找到了解决方案Intel Atom(x86) 而不是 ARM
我有一个使用 Android Studio 创建的 Android 项目。我在项目中添加了一些第三方依赖项,但是当我尝试在 Android Studio 中编译时,我遇到了以下错误: Error:Ex
如上所述,如何使用 API 8 获取移动设备网络接口(interface)地址? 最佳答案 NetworkInterface.getInetAddresses() 在 API8 中可用。 关于andr
我想显示 Snackbar并使用图像而不是文本进行操作。 我使用以下代码: val imageSpan = ImageSpan(this, R.drawable.star) val b
我有一个用 python 编写的简单命令行程序。程序使用按以下方式配置的日志记录模块将日志记录到屏幕: logging.basicConfig(level=logging.INFO, format='
使用下面的代码,实现游戏状态以控制关卡的最简单和最简单的方法是什么?如果我想从标题画面开始,然后加载一个关卡,并在完成后进入下一个关卡?如果有人能解释处理这个问题的最简单方法,那就太好了! impor
我想创建一个可以找到嵌套树结构深度的属性。下面的静态通过递归找出深度/级别。但是是否可以将此函数作为同一个类中的属性而不是静态方法? public static int GetDepth(MenuGr
var myArray = [{ title: "Title 1", children: [{ title: "Title 1.1", children: [{
通过下面的代码,实现游戏状态来控制关卡的最简单、最容易的方法是什么?如果我想从标题屏幕开始,然后加载一个关卡,并在完成后进入下一个关卡?如果有人可以解释处理这个问题的最简单方法,那就太好了! impo
我有一个树结构,其中每个节点基本上可以有无限个子节点,它正在为博客的评论建模。 根据特定评论的 ID,我试图找出该评论在树中的深度/级别。 我正在关注 this guide that explains
考虑任何给定的唯一整数的数组,例如[1,3,2,4,6,5] 如何确定“排序度”的级别,范围从 0.0 到 1.0 ? 最佳答案 一种方法是评估必须移动以使其排序的项目数量,然后将其除以项目总数。 作
我如何定义一个模板类,它提供一个整数常量,表示作为输入模板参数提供的(指针)类型的“深度”?例如,如果类名为 Depth,则以下内容为真: Depth::value == 3 Depth::value
我的场景是:文件接收器应该包含所有内容。另一个接收器应包含信息消息,但需要注意的是 Microsoft.* 消息很烦人,因此这些消息应仅限于警告。两个sink怎么单独配置?我尝试的第一件事是: str
我是一名优秀的程序员,十分优秀!