java应用性能指标_性能与可靠性:Java应用为何像F1汽车

java应用性能指标

再想一想。

性能和可靠性相关吗? 还是这些东西相互排斥? 我认为是后者。 如今,现实是IT部门将应用程序的性能和可靠性视为同一事物,但这离事实还差得远。

让我们看看一级方程式车队如何管理性能和可靠性。

上赛季迈凯轮本田车队既慢又不可靠。 法拉利本赛季在排位赛中表现很快,但是在比赛中并不可靠。 另一方面,梅赛德斯在过去的两年中一直超级敏捷,超级可靠,这让所有人都望而却步。

性能

F1赛车通常受以下三个因素影响:动力单元,发动机映射和空气动力阻力/下压力。

引擎图指示了动力单元从可用资源(空气,燃料和电力)中消耗了多少资源。 空气动力阻力/下压力由汽车周围的气流管理方式决定。

更大的功率和更低的阻力意味着更少的阻力,更快的加速度和更高的顶端速度。

下压力越大,拐角处的抓地力/速度越大。 性能就是F1赛车在赛道上跑得有多快。 F1车队在一个典型的周末将对汽车的设置进行数百次更改,希望每十分之一秒都能解锁一次,这样他们就可以超越排位赛并参加比赛。

同样,应用程序性能受三件事影响:JVM运行时,应用程序逻辑和事务流。

应用程序逻辑消耗了JVM运行时的资源(线程,cpu,内存等),并且事务流由每个事务必须跨越基础结构组件或第三方Web服务进行的跃点数决定。

性能与计时最终用户请求(页面/事务)以及了解应用程序逻辑和事务流之间的端到端延迟有关。 像F1工程师这样的开发人员将进行数百项更改,希望优化最终用户体验,从而使业务受益。

性能的主要度量单位是响应时间,因此,在管理此性能时,诸如AppDynamics,New Relic和Dynatrace之类的Application Performance Monitoring(APM)解决方案是头等大事。

可靠性

F1赛车通常受其工程组件,赛车ECU和百万传感器输入,参数和功能的质量影响。

一些意外参数,赛车将立即停止。 去年,尼科·罗斯伯格(Nico Rosberg)两次发生事故,当时他的方向盘和电子设备停滞不前。

对F1汽车的性能进行故障诊断与对其可靠性进行故障诊断有很大不同,它们是有些不同的用例,需要不同的遥测,工具和观点。 可靠性是关于了解事情为什么破裂以及事情为什么运行缓慢的原因。

对应用程序的处理相同,只是当应用程序崩溃时,这是因为应用程序逻辑在某处发生故障,从而引发了错误或异常。 这与运行缓慢的应用程序逻辑有很大不同。

应用程序逻辑接受输入,对其进行处理并创建某种输出。 与F1赛车一样,应用程序具有成千上万个具有数百万行代码的组件(功能),每个代码行可同时处理数十万个参数(对象和变量)。 没有可靠性,性能无关紧要。 日志文件是错误和异常所在的地方。

问题:慢航班搜索比航班预订错误重要吗?

答案:它们都会杀死企业,因此您需要同时管理两者。

维珍大西洋

航班预订失败

欢迎来到废话数据世界

假设这些APM解决方案在管理性能方面做得很好。 我们的行业仍然坚信,日志文件(或某些供应商称之为大数据)是理解应用程序失败原因的答案。 我实际上将这种方法称为“废话数据”。

日志文件缺乏深度,上下文和洞察力,对于任何真正想找到应用程序故障的真正根本原因的人来说。 当然,日志文件总比没有好,但是让我们看一下开发人员需要哪些数据才能始终找到根本原因:

  1. 应用程序堆栈跟踪 –显示哪个应用程序组件(类/方法)是故障的一部分
  2. 应用程序源代码 –显示导致失败的代码行
  3. 应用程序状态 –显示组件/源代码处理的应用程序参数(对象,变量和值)

今天,大多数日志文件将包含数百万个重复的应用程序堆栈跟踪。 这就是Splunk之所以价值60亿美元的原因,因为每条重复的堆栈跟踪信息都会花费$$$来解析,索引,存储和搜索。

是的,开发人员可以自定义应用程序日志以将所需的任何数据放入其中。 坏消息是,由于开销,开发人员无法记录所有内容,而创建有意义的日志通常需要知道将在应用程序中破坏什么。

没有水晶球,就不可能创建有效的日志文件,这就是为什么团队仍然要花费数小时或数天来寻找大海捞针的原因。 没有应用程序源代码或状态意味着操作和开发必须猜测。 这不好。 不幸的是,堆栈跟踪是不够的。 在F1中,这就像梅赛德斯维修站工作人员告诉他们的工程师“我们的遥测技术刚刚确认Nico的方向盘坏了,这是我们仅有的遥测技术–您能找出原因并尽快修复它”。

您能想象工程师会怎么想吗? 不幸的是,这是大多数开发人员今天在得知应用程序出现故障时的想法。

好消息是,现在可以知道生产中何时以及为何中断应用程序代码。 欢迎来到塔基皮 。

现在,不可能的事情成为可能,并且日志文件到此结束。

翻译自: https://www.javacodegeeks.com/2016/04/performance-vs-reliability-java-apps-like-f1-cars.html

java应用性能指标

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

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

相关文章

tomcat ajp协议安全限制绕过漏洞_Apache Tomcat文件包含漏洞(CVE20201938)复现

一、漏洞背景2020年02月20日,国家信息安全漏洞共享平台(CNVD)发布了关于Apache Tomcat文件包含漏洞(CVE-2020-1938/CNVD-2020-10487)的安全公告。Tomcat作为一款免费开源轻量级的web应用服务器,广泛应用于并发量不是很高的场合,Tomact默认端口…

【H.264/AVC视频编解码技术】第三章【熵编码】

熵编码的概念 熵:化学与热力学概念,用于度量能量退化的指标。熵越高,物体/系统做工能力越低。 信息学中的熵:用于度量消息的平均信息量,和信息的不确定性。越是随机的,前后不相关的信息,其熵越…

mock 抛出一个异常如何终止_教你使用Mock完成单元测试

更多精彩文章请关注本人微信公众号1、什么是Mock?mock是在测试过程中,对于一些不容易构造/获取的对象,创建一个mock对象来模拟对象的行为。比如说你需要调用B服务,可是B服务还没有开发完成,那么你就可以将调用B服务的那部分给Moc…

jconsole查看连接数_在JConsole和VisualVM中查看DiagnosticCommandMBean

jconsole查看连接数我已经将JConsole用作合适的通用JMX客户端已有很多年了。 该工具通常随Oracle JDK一起提供,并且易于使用。 在JMX交互方面,JConsole优于VisualVM的最大优点是JConsole带有内置的MBeans选项卡,而必须为VisualVM中的相同功能…

如何知道一个域名是否存在_域名检测API实现查看一个域名在微信中是否被封

针对微信转发分享链接过程中,您宝贵的域名被微信检测系统过滤拦截而无法正常浏览,例如该网页包含诱导分享内容,被多人投诉等,又例如提示该网页已停止访问等提示。怎么查询域名在微信中是否被封了呢?以上接口可检测到域名的四种异…

量化指标公式源码_通达信指标公式源码线上阴线指标公式

工作线:(EMA(C,14)),POINTDOT,LINETHICK3,COLOR22ACDE;生命线:(MA(C,25)),LINETHICK1,COLORMAGENTA;不惑线:(MA(C,40)),COLORCYAN,LINETHICK1;姊妹线:(EMA(C,56)),POINTDOT,COLOR33CCDD,LINETHICK1;A3:EMA((((SLOPE(C,21)) * 20) C),68);A4:EMA(C,10);A5:REF(C,2);A6:((SMA((M…

jsf和jsp_带有JSF,Servlet和CDI的DynamicReports和JasperReports

jsf和jsp在此示例中,我将展示如何将DynamicReport和JasperReports与Servlet和CDI集成。 工具: TIBCO Jaspersoft Studio-6.0.4。最终版 Eclipse Luna服务版本2(4.4.2)。 WildFly 8.x应用程序服务器。 这是Eclipse上项目层次结…

接口隔离原则_设计模式的三大分类及六大原则

设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。设计模式分为三大类&…

Leetcode 24. 两两交换链表中的节点

原题链接 题解: 1.头部会改变创建虚拟头结点 2.前两个点定义为a,b,c 3.p指向b,a指向c,b指向a ; p指向本段最后一个结点。 class Solution { public:ListNode* swapPairs(ListNode* head) {auto dummy new ListNode(-1);dummy->next head;for (a…

python 获取文件名_真实需求 | Python+os+openpyxl 批量获取Excel的文件名和最大行数...

1. 提出需求 这已经不知道是粉丝问我的第几个办公自动化的问题了,并且这些问题都是大家在学习和工作中碰到过的真实问题场景。其实从下图中已经可以很明确的看出别人的需求了,我这里就不用在赘述了,下面直接上思路吧!2. 解题思路为…

apache ignite_从In Memory Data Grid,Apache Ignite快速入门

apache igniteIMDG或内存数据网格不是内存中关系数据库,NOSQL数据库或关系数据库。 它是另一种软件数据存储库。 数据模型分布在单个位置或多个位置的许多服务器上。 这种分布称为数据结构。 这种分布式模型被称为“无共享”架构。 IMDG具有以下特征: 所…

bvp解算器是什么_那些学习了编程的中学生,为什么会更可能成功?

来源 | 异步当你看到这个题目,或许会想,这不是搞笑吗?众所周知,高等数学是编程的基础和前提,而说起程序编写员,在普通人眼里就是数学学霸的代名词,人们往往会把它和那些数学天才的名字联系在一起…

maven与spring_与Spring和Maven签约首个SOAP服务

maven与spring1.简介 在本教程中,我们将学习使用JAX-WS,Spring和Maven实施合同优先的SOAP服务应用程序。 这是使用合同优先还是代码优先方法的更多设计决定。 在开发基于SOAP的Web服务应用程序时使用应用合同优先的方法最显着的好处是,可以在…

如何维持手机电池寿命_充电小知识:你知道如何正确充电吗?这几种充电方式最损害电池...

目前基本上大部分人都至少有一部智能手机,智能手机基本上都需要每日一充,你的充电方式会不会损伤电池呢?有部分消费者认为要等到手机电量耗尽后再充电,还有人认为手机充电要充至100%才能拔下来,有人觉得充电宝等产品给…

【开放集检测】OpenGAN: Open-Set Recognition via Open Data Generation 论文阅读

文章目录 英语积累为什么使用GAN系列网络进行开放集检测摘要1. 前言2. 相关工作开集检测基于GAN网络的开集检测基于暴露异常数据的开集检测 3. OpenGAN3.1 公式建模3.1.1 二分类方法存在问题如何解决 3.1.2 使用合成数据存在问题如何解决 3.1.3 OpenGAN3.1.4 模型验证 3.2 先前…

sso集成shiro_Keycloak SSO集成到jBPM和Drools Workbench中

sso集成shiro介绍 单一登录(SSO)和相关令牌交换机制正在成为Web上不同环境中身份验证和授权的最常见方案,尤其是在迁移到云中时。 本文讨论了Keycloak与jBPM或Drools应用程序的集成,以便使用Keycloak上提供的所有功能。 Keycloak…

jbpm 和 drools_jBPM和Drools工作台中的用户和组管理

jbpm 和 drools介绍 本文讨论了一项新功能,该功能允许使用集成在jBPM和Drools Workbenches中的直观友好的用户界面来管理应用程序的用户和组。 用户和组管理 在安装,设置和使用此功能之前,本文讨论了一些以前的概念,需要进一步理…

从事java编程技能要求_5道Java视频课程,提高您的编程技能

从事java编程技能要求作为Web开发人员,跟上技术知识可能会很棘手。 新技术似乎每天都在弹出,而基本技术也看到了重复迭代的浪潮,增加了新的功能。 Java开发人员应该做什么? 这是在线教育平台发挥作用的地方。 它们可以帮助您快速…

sqlserver存储过程加锁后怎么解锁_【缺陷周话】第59期:重复加锁

聚焦源代码安全,网罗国内外最新资讯!*声明:《缺陷周话》栏目系列文章由奇安信代码卫士团队原创出品。未经许可,禁止转载。转载请注明“转自奇安信代码卫士 www.codesafe.cn”。代码审计是使用静态分析发现源代码中安全缺陷的方法&…

idea添加jboss_如何将云持久存储添加到JBoss Cool Store

idea添加jboss我们一直在讨论为什么应用程序开发人员在App Dev Cloud Stack系列中不能再忽略其堆栈了。 带有JBoss Cool Store的App Dev Cloud 上个月,我们带来了一个完整的零售示例,其中的JBoss Cool Store运行在您的堆栈的OpenShift Enterprise层上&…