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

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

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

错误处理

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

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

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和集成项目支持。我的专长…

mysql max pool_asp.net连接mysql得到错误all pooled connections were in use and max pool size was reach...

asp.net连接mysql数据库时,得到以下错误信息MySql.Data.MySqlClient.MySqlException (080004005): error connecting: Timeout expired. The timeout period elapsed prior to obtaining a connection from the pool. This may have occurred because all pooled co…

科尔达服务101

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

python写入数据到excel_python实现查询的数据写入到excel

#codingutf-8 import sys import xlwt import pymysql as MySQLdb #这里是python3 如果你是python2.x的话,import MySQLdb import datetime host 192.168.10.109 user root pwd port 3306 db com66nao_mi sheet_name report out_path rD:\SQL\aaa.xls print…

1899-11-30 php mysql_PHP学习十一--PHP操作MYSQL数据库

1.PHP访问Mysql数据库的一般步骤连接MySQL服务器选择MySQL数据库请求 执行SQL语句 请求MySQL数据库服务器 关闭结果集 数据资源响应 关闭MySQL服务器 响应(1).连接MySQL服务器。通过…

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

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

python运行pyc文件_Python什么情况下会生成pyc文件?

作为Python爱好者,需要了解.py脚本的基本运行机制及特性: 在很多工作上Python的运行流程基本上取决于用户,因此源码不需要编译成二进制代码(否则无法实现大部分贴近用户的特性),而直接从源码运行程序。当我…

mysql 8.0认证失败_连接mysql8.0提示认证协议失败

描述用docker容器安装软件非常方便,省了太多麻烦。通过docker运行mysql8.0,再用navicat客户端连接出现client does not support authentication protocol requested by server。像似认真失败,检查mysql.user表,已经配置了用户,为什…

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

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

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

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

mysql 注入 file load_Mysql注入中into outfile和load_file()总结

(1)outfile后面不能接0x开头或者char转换以后的路径,只能是单引号路径。这个问题在php注入中更加麻烦,因为会自动将单引号转义成\,那么基本没的玩了。唯一的一种可能就是你使用mysql远程连接,然后直接在mysql中执行命令,就没有查询…

vscode python单步调试_调试期间VSCode python“未验证断点”?

我正在使用VSCode调试python应用程序。在我有一个主python文件,从这里启动调试器。我可以在这个文件中放置断点,但是如果我想在主文件调用的其他文件中放置断点,我会将它们作为“未验证的断点”得到,调试器会忽略它们。在如何更改…

您自己的MicroProfile Config来源

MicroProfile配置 ,即一部分MicroProfile规格,是Java Enterprise和微服务配置的标准化。 开箱即用(即,对于规范定义的所有实现都是强制性的)有3种方法来定义您的配置: System.getProperties() System.ge…

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

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

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

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

tpcc mysql优化_tpcc_mysql性能测试

. bzr branch lp:~percona-dev/perconatools/tpcc-mysql该方法需要下载bzr工具,还要在网站注册并添加SSH KEY,非常麻烦,并且还没有成功(卡在SSH KEY上)。2. 直接在 http://bazaar.launchpad.net/~percona-dev/perconatools/tpcc-mysql/files …

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

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