- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
随着越来越多的努力将软件 block 分成独立的层并使用动态发现和依赖注入(inject)将它们解耦,确定系统中的哪个“层”导致“应用程序”的系统范围故障变得越来越困难".
单元测试有助于确保构成一个层的所有“模块”都按预期工作。但是单元测试的编写方式是通过使用 stub 和模拟等技术隔离每个“模块”。
考虑下面的简单示例:
L1。数据库 -> L2。数据库层 -> L3。 Windows 服务 -> L4。客户申请
例如,如果数据库引擎宕机,那么系统将无法正常运行。很难判断数据库引擎是真的宕机了,还是数据库层 (L2) 代码中存在错误。要进行检查,您必须启动某种数据库管理工具来检查数据库引擎是否正在运行。
我们正在努力实现的是一个开发人员工具,只要系统“出现问题”就可以启动,这个工具将“查询”每一层的“完整性”或“诊断”数据。该工具将提供软件层列表及其“完整性状态”。然后它将能够立即说 X 层是问题的原因(即数据库引擎已关闭)。
当然,每一层都会负责提供自己的“诊断方法”,可供工具查询。
我想我们在这里试图实现的是某种“集成测试”框架或类似的东西,可以在运行时使用(而不是像单元测试那样的编译/构建时间)。灵感来自具有自己的“车载诊断”的物理设备,例如汽车。软件世界中的一个很好的例子是每次打开计算机时都会运行的开机自检。
有人见过或听过这样的事情吗?任何建议或指示肯定会有很大帮助!
最佳答案
您可以拥有一个公共(public)接口(interface),每个层都将实现为 WCF 服务。这样你就可以连接到每一层并对其进行诊断。提供此诊断可能很有用,但如果您想在任何地方(每一层)实现它,那将是另一件可能会失败的事情——您将如何诊断它?您的系统会大量使用 WCF 服务,这并不好,因为它需要大量维护并使其不太稳定。此外,它需要大量工作才能实现。
我建议的替代方案是建立一个良好的日志记录系统。最低限度是让每个模块在所有 catch
部分记录一个错误,但我建议不止于此,尤其是为了调试目的。我推荐使用免费且非常灵活的 Log4Net。它在不需要时不记录是有效的,这意味着您可以将日志记录级别设置为高,并且即使在生产代码中也不会影响性能。您可以通过更改配置文件中的设置在运行时更改日志记录级别。我经常使用 Log4Net,它运行良好。
一旦您有了代码日志记录的东西,您就可以配置 Log4Net,以便所有日志都进入中央数据库。然后,您将有一个地方可以相对容易地诊断发生了什么、什么失败了、异常或消息在哪里以及什么是异常或消息。您甚至可以设置在出现问题时发送的电子邮件。
关于testing - 软件层的自诊断测试?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11349126/
前言 在进行Maven开发时,往往需要下载大量jar包,而由于网络不稳定等其他因素可能导致jar未下载完毕,然后保留了lastUpdated文件,导致无法更新失效的jar包。 本文分享 bat脚本,自
按字母顺序排序并不是我们花太多时间担心的事情。我们在很小的时候就学习了字母表,现在我们知道它(拉丁文)以 A 开头,然后是 B,然后是 C 等等,一直到 Z。 但是这个订单究竟存储在计算机系统中的什么
我尝试使用可分离为 2 个一维向量的二维矩阵来证明二维傅里叶变换的信号属性的可分离性。地点: f(x,y) = f(x)*f(y) 那么 F(u,v) = F(u)*F(v) 使用以下代码: % Se
我需要为几个小型sqlite数据库编写文档。想描述数据的使用方式,包括表和行说明以及示例数据。 是否可以使用MySQL Workbench?如果没有其他选择,或者我可以使用任何模板? TIA! 最佳答
我正在尝试使用旧版本(例如:1.4.5)安装 memcached,但我不知道该怎么做。 brew install memcached安装最新的。 我也试过 brew install memecache
背景 多年来,我一直使用自己的类似贝叶斯方法,根据大型且不断更新的训练数据集对来自外部来源的新项目进行分类。 每个项目都有三种类型的分类: 30 个类别,其中每个项目必须属于一个类别,且最多属于两个类
嗨,我需要确定 4 个数字是否相等。数字是 size(A,1)、size(B,1)、size(C,1) 和 size(D,1),其中,例如A = [1 2; 3 4], B=[1 2 3, 4 5 6
Wikipedia 中的文章似乎太冗长了。 我将框架理解为一组精心设计的库和工具。 Qt 框架为跨平台 GUI 提供了一组库/工具。 cocoa 框架为 Mac 做了同样的事情。 软件框架的实际定义是
我们的客户最近发现了这个网站: http://mydeco.com/3d-planner/ 它有一个非常非常奇特且组合良好的 3d CAD Web 应用程序,似乎是使用 jQuery 编写的,而不是
我们正在寻找一种独立的(非 cms)日历解决方案来显示在网络上。它可以是开源的或付费服务。 我们主要是在寻找一种在 Web 上显示日历的方法,其中包含事件发生的时间和事件的名称。如果它可以按周、月、年
我想知道与软件相关的“质量保证”和“质量科学”之间的区别。 我在Google上进行了研究,但未找到有关“质量科学”的任何信息。 最佳答案 Based on the link you have prov
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我有一个由 2 个方程和 2 个未知数组成的系统,我想使用 MATLAB 求解,但不知道如何编程。我得到了一些有关 Gamma 分布的信息(平均值为 1.86,90% 的间隔介于 1.61 和 2.1
给定一个矩阵,其中 1 是当前子集 test = 0 0 0 0 0 0 0 0 0 0 0 0
我在组合 Matlab“数据”变量的重复元素时遇到问题。我可以使用 unique 和 sort 轻松组合这些值。 [sorted,idx] = sort(data); [~,ij] = unique(
我在做的问题中有这么一段代码,如下图。定义部分只是为了向您展示数组的大小。下面我粘贴了矢量化版本 - 它慢了 2 倍以上。为什么会这样?我知道如果矢量化需要大的临时变量,我就会发生,但(看起来)这里不
我有一个 3D 矩阵,我想将它的每个 2D 分量存储在另一个 2D 矩阵的行中,该 2D 矩阵有许多行作为 3D 矩阵的第 3 维。 我该怎么做? 最佳答案 与 permute & reshape -
如果计算机能够使用纯 JavaScript(Google V8)、C++(Windows、Mac OS 和 Linux)运行程序/软件而没有任何性能问题,是否有任何好的方法可以通过要求尽可能少尽可能从
我的团队的任务是将用于播放媒体文件的全屏、信息亭式应用程序从 Windows 迁移到嵌入式 ARM Linux(瘦客户端)。我们需要在 sd/1080p 中支持 mpeg-2 播放以及 HTML、SW
我们有数以千计的具有白色或黑色或渐变背景的产品图片。我们正在寻找可以去除图片背景的软件或服务。我们需要一款能够很好地完成这项工作的智能软件。 最佳答案 在 photoshop 中,您可以记录 Acti
我是一名优秀的程序员,十分优秀!