简单的测试可以防止最严重的故障

错误处理是软件开发中最困难且被忽略的部分之一,如果系统是分布式的,那么这将变得更加困难。

好的论文写在“ 简单测试可以预防最关键的故障” 主题上。

错误处理

每个开发人员都应该阅读本文。 我将尝试总结本文的主要内容,但建议阅读该论文以获取有关它的更多详细信息。

分布式系统中断很常见,最近的一些例子是

Youtube于2018年10月关闭约1小时以上

亚马逊在2018年7月的黄金交易日下跌

Google,Map,Gmail,Youtube等服务在2018年经历了无数次下滑

Facebook还面临着许多数据泄漏问题。

本文讨论了在分布式系统(如Cassandra,Hbase,HDFS,Redis,Map Reduce)中发生的灾难性故障。

根据纸张,大多数错误是由于2个原因引起的

–由于复杂的事件顺序而发生故障

–灾难性错误是由于处理不当造成的

–我将在我在“ 设计压力对工程团队”的帖子中写到第三篇关于“忽略设计压力”的文章

HBase中断示例

1 –负载平衡器从从站A到从站的传输区域R

2 –从站B的开放区域R

3 –主从属B拥有后,删除当前的Zookeeper区域R

4 –从属B模具

5 –将区域R分配给从属C和从属C打开区域

6 – Master尝试删除Zookeeper上的Slave B znode,并且由于错误的错误处理代码,slave b关闭并且整个集群关闭。

在上面的示例中,事件序列对于重现问题很重要。

当不复制块时,HDFS失败。

错误处理

在此示例中,事件序列也是如此,当新数据节点启动时,它将暴露系统错误。

纸上还有更多例子。

错误的根本原因

92%的灾难性错误是由于错误处理而发生的。

这意味着扣除了错误,但错误处理代码却不好,这听起来像您正在从事的许多项目!

1 –错误被忽略
这是25%失败的原因,我认为在许多实时系统中,这个数字会很高。

eg of such error
catch(RebootException e) {
log.info("Reboot occurred....")
}

是的,此无害的日志语句忽略了异常,是错误处理的非常常见的反模式。

2 –追赶异常
这也很常见,例如具有通用的catch块并破坏整个系统

catch(Throwable e) {
cluster.abort()
}

3 –评论中的TODO / FIXME
是的,生产中的实际分布式系统在代码的关键部分也有很多TODO / FIXME。

错误处理的其他示例

} catch (IOException e) { // will never happen  }} catch (NoTransitionException e) { /* Why this can happen? Ask God not me. */  }try { tableLock.release(); } catch (IOException e) {  LOG("Can't release lock”, e);  

4 –优先开发功能
我认为所有软件工程师都会同意。 这也称为技术债务,我想不出比Knight Capital破产更好的例子了,这是由于配置和实验代码所致。

结论

所有错误都是很复杂的,但是重现更好的单元测试肯定会抓住这些错误,这也表明,在许多系统中进行的单元/集成测试并不是在测试诸如服务中断并再次返回以及如何影响系统的场景。

根据上面的示例,看起来所有错误都是由于Java检查异常引起的,但是在其他系统(如C / C ++)中没有检查但未检查所有内容的情况却没有什么不同,开发人员有责任在各个地方进行检查。

附带说明一下,没有像Python这样的类型系统的语言使编写在运行时中断的代码变得非常容易,并且如果您真的很不幸,那么错误处理代码将出现类型错误,并且将在生产中进行测试。

同样,几乎所有产品都将具有一些静态代码工具(findbugs)集成,但是这些工具并没有更加重视这种错误处理反模式。

链接到论文中提到的问题

HDFS

MapReduce

HBase的

雷迪斯

卡桑德拉

请分享您在生产系统中看到的更多反模式。

直到快乐的单元测试。

翻译自: https://www.javacodegeeks.com/2018/10/simple-testing-prevent-critical-failures.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/346463.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sql 两个 in_SQL基础知识——IN运算符

IN的作用IN运算符允许您在WHERE子句中指定多个值。IN运算符是多个OR条件的简写。IN的语法SELECT column_name(s) FROM table_name WHERE column_name IN (value1, value2, ...);或者SELECT column_name(s) FROM table_name WHERE column_name IN (SELECT STATEMENT);示例数据库…

pythonlist循环添加元素_python中 for循环之后 添加元素到列表失败?

import re ls list() dc dict() # 介词、连词、人称代词等自己统计 adverb [i, you, he, she, it, in, on, with, by, for, at, about, under, of, to, and, or, therefore, so, of, a] with open("老人与海.txt", moder, encodingutf-8) as f: lryh f.read() # …

开始协议处理句柄_基于smb协议的wmiexec浅析

前言之前研究过Crackmapexec这款工具,对这个工具基于smb协议的wmiexec执行方法产生的流量进行了分析,网上似乎还没有相关的文章,这里旨在抛砖引玉,简单梳理下整个过程,以初学者的视角,探索流量当中存在的奥…

apache camel_轻量级的开源集成:Apache Camel还是Spring集成?

apache camel首先,为全面披露信息,在过去的1.5年中, 我一直担任 FuseSource(现为Red Hat) 的顾问,为零售,运输,银行/金融等不同行业的大型和小型公司提供SOA和集成项目支持。我的专长…

科尔达服务101

我今天想写一篇简短的要点文章。 我真的很好奇我能多快出版此书。 所以走吧 这篇文章是关于Corda Services(使用Corda 3.2版)的。 这些是什么? 作为经常使用Spring的开发人员,我个人会说它们就像Beans。 Spring Beans可以做的还很…

intent隐式和显式_Neo4j:使隐式关系成为显式和双向关系

intent隐式和显式我最近阅读了Michal Bachman关于 Neo4j中双向关系的文章 ,他建议对于某些关系类型,我们对关系的方向不那么感兴趣,因此可以在查询时忽略它。 他使用以下示例显示Neo Technology和GraphAware之间的合作关系: 两家…

mysql读写分离 存储过程_基于maxscale的读写分离部署笔记

使用maxscale搭建的读写分离架构,后期还可以再结合MHA做master的故障转移,这样业务层面上不需要做任何的改动即可。基于connect方式的不要使用。从库延迟他还会继续分发请求过去,暂时不适合生产使用。实验演示:目前的主从结构&…

python读书笔记2000_流畅的Python读书笔记

特殊方法的存在是为了Python解释器调用的,你自己并不需要去调用他们,比如说my_object.len()这种写法是没有的,应该使用len(my_object)。在使用len(my_object)的时候,如果my_object是一个自定义类的对象,那么Python会自…

antd 3升级命令_是时候拥有一个你自己的命令行工具了

本篇博客主要介绍了如何使用commander, inquirer以及chalk从零开始,创建属于自己的命令行工具。0. 一分钟体验首先我们先花一分钟的时间,体验一下创建自己的命令行cli工具是什么感觉。0.1. 新建项目目录假如我们的项目名称叫hello-cli,使用如…

找不到要去的声明_老汉将行李袋交由他人看管 去了一趟卫生间找不到人了.........

春节走亲访友难免多喝两杯,但酒后乘车却容易造成财物遗失。目前正值春运返程高峰,从沧州女儿家返程回山东老家的蔡先生就因为中午多喝了几杯酒,便将装有12000元生活费的行李袋弄丢了。好在沧州火车站派出所民警最终将蔡先生的失物找回&#x…

java可视化压缩_web可视化技术发展(1/6)

EverCraft一直在关注Web可视化技术的发展,在本系列文章里,小编将对国外一篇感觉很不错的综述性文章进行翻译,供这一领域的爱好者相互学习。这篇paper的信息为:“Mwalongo, F., et al., State-of-the-Art Report in Web-based Visu…

屏幕坏点检测图片_电视屏幕出现坏点?行家会这样做!

液晶电视经常会有几个亮点或暗点,这些通常被称为电视坏点。作为强迫症患者,面对这些屏幕坏点我们应该怎么做?下面跟小智聊聊这个问题吧!首先,坏点形成的原因首先是因为液晶屏幕由很多点组成,每个点由RGB三原…

Java:GraalVM数据库流性能

GraalVM是JVM块的新成员。 它是一个开源虚拟机,能够同时运行多种编程语言,例如Java,Rust和JavaScript。 GraalVM还有一个新的内部代码优化器管道,在某些情况下,与其他JVM相比,它可以显着提高性能。 了解如何…

kubelet启动失败_kubelet 架构浅析

一、概要kubelet 是运行在每个节点上的主要的“节点代理”,每个节点都会启动 kubelet进程,用来处理 Master 节点下发到本节点的任务,按照 PodSpec 描述来管理Pod 和其中的容器(PodSpec 是用来描述一个 pod 的 YAML 或者 JSON 对象…

shell 提取sql 的字段名表名_SQL代码风格规范

作为新时代SQL Boy,大部分时间都是在写sql,很多时候看到别人写的代码实在是不规范,命名随便写,没有缩进,看起来很没有逻辑性,今天分享下我自己的一些规范,从这里修改而来。--名称:xx…

亚马逊ec2 实例删除_亚马逊免费使用套餐:在EC2 Linux实例上安装Tomcat 7

亚马逊ec2 实例删除Amazon Web Services提供了12个月的免费使用期限,使开发人员可以在云中运行任何他们想要的东西。 免费层包括14个服务,其中Web开发人员最关注EC2服务。 EC2是一项服务,通过停止和启动Windows和/或Linux的虚拟实例来提供可调…

使用混合多云每个人都应避免的3个陷阱(第4部分)

每天都在肆意宣传云,但每个人都应避免三个陷阱。 从云,混合云到混合多云,您被告知这是确保业务数字化未来的一种方式。 您必须做出的这些选择不会排除提高客户体验和敏捷交付这些应用程序的日常工作。 让我们开始一段旅程,仔细研…

Java,JavaFX的流畅设计风格拨动开关

嗨,这次我将在新版本的JMetro中讨论新的Toggle Switch样式。 拨动开关是一种近年来变得非常流行的控件。 我前一段时间在ControlsFX库中添加了JavaFX实现。 刚刚发布的JMetro版本4.1中提供了此新样式。 什么是拨动开关 在以前的文章中,我谈到了切换开…

python解析多层嵌套json_Python爬虫解析多个嵌套JSON,多级,json

Python爬虫解析多级嵌套json最近刚接触Python爬虫,正好最近肺炎在全国蔓延,所以准备从网站爬取肺炎实时数据,并解析自己想要的数据。获取json数据网址为 https://m.look.360.cn/events/feiyan爬取网址:def main():urlhttps://m.lo…

如何使用vps 异地组网_使用ZEROTIER异地组建内网(局域网)

一、注册账号(该网站打开比较慢,但并不影响组网后的网速)二、建立虚拟局域网网(获取Network ID)1.选择菜单栏的Networks菜单2.选择创建网络3.注意获取到的Network ID(需要在每台组网的电脑上加入这个network id)4.大部分设置默认就可以了.三、下载软件点菜单中的Dow…