java实现资源监视器_实现Java监视的12个步骤程序存在缺陷

java实现资源监视器

Java监视的当前状态最大的问题是什么?

生产中的错误很像喝醉的短信。 您只有在事情已经发生之后才意识到出了点问题。 发短信日志通常比应用程序错误日志更有趣,但是……两者可能同样难以修复。

在本文中,我们将执行一个12步的监视漏洞修复程序。 由Takipi用户的经验支持的思想实验,解决了您可能会遇到的一些最常见问题–以及您可以如何解决这些问题。

来吧。

步骤#1:承认我们有问题

实际上,这只是更高级别的问题之一,即应用程序可靠性。 为了能够快速了解​​应用程序何时出现问题,并能够快速访问所需的所有信息以进行修复。

当我们走近一步时,可靠性问题由监视和日志记录的当前状态下的许多其他症状组成。 这些是大多数人试图掩埋或完全避免的棘手问题。 但是在这篇文章中,我们将它们放在了焦点。

底线:不可避免地要对生产中出现的新错误进行故障排除和处理。

步骤2:关闭监控信息过载

一个好的做法是收集有关应用程序的所有信息,但这仅在度量标准有意义时才有用。 如果仅是事后考虑,不一致的日志记录和度量标准遥测会产生更多噪声。 即使它们产生漂亮的仪表板。

其中很大一部分是将异常和已记录的错误滥用为应用程序控制流的一部分,从而以“正常”异常的悖论堵塞了日志。 您可以在最近的电子书,我们发布了关于此这里 。

随着监视和数据保留成本的降低,问题开始转移到收集可行的数据并使之有意义。

底线:尽管逐渐变得更容易记录和报告所有内容,但错误根本原因的发现仍然主要是手动的,大海捞针变得更大,更难找到针头。

步骤#3:避免繁琐的日志分析

假设我们有一些错误,一个特定的事务有时会失败。 现在,我们必须在日志文件中找到有关它的所有相关信息。 是时候翻阅日志,或者在诸如Splunk,ELK或其他日志 管理工具之类的可以使搜索更快的工具中处理各种查询。

为了使此过程更容易,使用Takipi的开发人员能够将每个记录的错误,警告和异常的上下文扩展到导致它的源,状态和变量状态。 每条日志行都有一个链接附加到该链接,从而可以在Takipi中进行事件分析:

日志链接

底线:手动筛选日志是一个繁琐的过程,可以避免。

步骤#4:意识到生产日志级别不够详细

原木水平是一把双刃剑。 您登录生产的级别越多,您拥有的上下文就越多。 但是,额外的日志记录会产生开销,最好在生产中避免。 有时,您需要的其他数据将出现在“ DEBUG”或“ INFO”消息中,但是生产应用程序通常仅写入“ WARN”级消息或更高级别。

我们在Takipi中解决此问题的方法是使用最近发布的新功能,该功能使您能够查看线程中导致错误的最后250条日志语句。 即使它们没有在生产中写入日志文件。

等一下 无日志记录,无额外开销。 由于日志语句是直接在内存中捕获的,而不依赖于日志文件,因此我们能够在生产中进行完整的详细描述,而不会影响日志大小或增加开销。 您可以在此处阅读有关它的更多信息,也可以自己尝试 。

底线:从今天开始,您不仅限于WARN或更高级别的生产日志记录。

步骤#5:下一个说“无法复制”的人买了一轮饮料

推迟错误修复的最常见借口是“无法复制”。 缺少导致错误的状态的错误。 某些不好的事情会发生,通常您首先会从实际用户那里听到它,并且无法重新创建它或在日志/收集的指标中找到证据。

从根本上讲,“无法复制”的隐藏含义是正确的。 如果您习惯于第一次听到来自用户的错误,则内部跟踪错误的方式可能有问题。 通过适当的监视,可以在实际用户报告错误之前识别并解决错误。

底线:停止复制“无法复制”。

复制

步骤#6:打破日志语句重新部署周期

一种常见的臭名昭著且不幸的“无法复制”的解决方法是在生产中添加其他日志记录语句,并希望该错误再次发生。

在生产中。

搞乱真实用户。

那就是生产调试悖论。 发生了一个错误,您没有足够的数据来解决它(但是您确实有很多杂音),添加了日志记录语句,进行了构建,测试(首先错过了该错误的同一测试),部署到生产环境,希望为使它再次发生,希望新数据足够或…重复。

底线:成功的监视策略的最终目标是防止此周期的发生。

步骤#7:APM +跟踪器+指标+日志=可见性受限

让我们提高一个等级。 我们已经介绍了日志和仪表板报告指标,现在是时候添加错误跟踪工具 和 APM了。

事实是,即使监视堆栈包括所有4个类别的解决方案,您进入应用程序错误的可见性也受到限制。 您将看到事务的堆栈跟踪,或者最多看到特定的预定义硬编码变量。 传统的监视堆栈在出现错误时无法查看应用程序的完整状态。

底线:在当今的通用监视堆栈中,有一个关键的缺失组件。 生产调试具有可变级别的可见性。

步骤#8:为分布式错误监控做准备

监视不会在单个服务器级别上停止,尤其是在微服务体系结构中,在一台服务器上形成的错误可能会在其他位置引起麻烦。

尽管微服务提倡“关注分离”原则,但它们还在服务器级别上引入了许多新问题。 在上一篇文章中,我们讨论了这些问题,并提供了可能的解决方案策略。

底线:任何监视解决方案都应考虑分布式错误,并能够对来自多个源的数据进行故障排除。

步骤#9:找到解决方法,以解决较长的故障排除周期

无论是警告问题还是仅是优先事项,对于大多数应用程序来说,在引入第一个错误之后,故障排除周期都需要数天,数周甚至数月的时间。 报告该错误的人员可能无法访问或更糟,由于数据保留策略,相关数据可能长期/延期。

在这种情况下,即使在错误时刻冻结应用程序状态快照的能力(即使它来自多个服务/源)也至关重要,否则,重要数据可能会丢失。

底线:应避免较长的故障排除周期。

步骤#10:确认开发人员与运营商的困境

跟上发布周期的问题,我们所有人都在同一条船上,但是,开发人员希望更快地发布功能,而运营则希望保持生产环境的稳定。

短的功能周期和长的故障排除周期根本不会在一起。 两者之间应保持平衡。 监视是一项团队运动,并且工具必须知道如何相互交谈。 例如,在Takipi,您可以获得有关Slack,Pagerduty或Hipchat的警报,并直接打开JIRA凭单,其中包含所有可用的错误分析数据。

底线:协作工作流程加快了问题解决的速度。

步骤#11:有希望

现代开发人员工具正在采取重大措施来改善当前的监视状态。 无论是在日志,应用程序性能管理领域还是在进行中的新类别。

底线:密切注意工具生态系统的发展以及其他公司的最佳实践。

步骤#12:宣传

监视是软件开发中不可分割的一部分,让我们继续进行讨论吧!

我们希望您对当前监视状态的一些主要问题感到满意/概述。 监控还有其他问题让您彻夜难眠吗?

请随时在下面的评论部分中分享它们。

翻译自: https://www.javacodegeeks.com/2016/08/12-step-program-realizing-java-monitoring-flawed.html

java实现资源监视器

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

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

相关文章

hystrix应用 博客_使用Hystrix DSL创建弹性骆驼应用程序

hystrix应用 博客Apache Camel是一个成熟的集成库(到现在已有9年的历史了),它实现了Enterprise Integration Patterns一书中的所有模式。 但是Camel不仅是EIP实现库,它还是一个不断发展,添加新模式并适应行业变化的现代…

notebook打开外部文件_CAD外部参照真是个好东西!

好课推荐:零基础CAD:点我CAD室内:点我 周站长CAD:点我CAD机械:点我 Bim教程:点我CAD建筑:点我CAD三维:点我全屋定制:点我 ps教程:点我苹果版CAD:点我 3dmax教…

JSP动作元素/活动元素

文章目录jsp:forwardjsp:includejsp:paramjsp:useBeanjsp:setPropertyjsp:setProperty name"" property"" value""jsp:setProperty name"" property"" param""jsp:setProperty name"" property"*&…

gradle groovy_适用于Java开发人员的Groovy吗? 认识Gradle,Grails和Spock

gradle groovyJava开发人员最感兴趣的Groovy用例有哪些? 尽管已经有一段时间了,但似乎只有Groovy最近才开始使用Groove。 对于某些人来说,它基本上只是另一种深奥的JVM语言,但是由于一些流行的工具可以帮助您使用Java&#xff0c…

JSP 指令元素

文章目录page 指令import 属性pageEncoding 属性contentType 属性session 属性isELIgnored 属性errorPage 属性isErrorPage 属性include 指令file 属性taglib 指令uri 属性prefix 属性jsp 源文件转换成对应的 .java 文件时,jsp 的指令会影响 Java 源代码的生成&…

indesign中调出字符样式快捷键_Word中十大黄金快捷键,你会用几个?

在使用Word文档时,熟练使用快捷键能够有效的提升我们的工作效率,但是,Word中快捷键也比较多,要想全部掌握,那不太现实,这里,易老师给大家挑选了10组黄金快捷键,非常实用。01 快速移动…

couchbase集群_使用CLI扩展和重新平衡Couchbase集群

couchbase集群Couchbase通过多种方式提供高可用性和灾难恢复 : 同质簇 复写 集群内复制 备份还原 机架区意识 该博客将展示如何使用Couchbase命令行界面(CLI)创建Couchbase集群。 此外,还可以使用Couchbase REST API和Couchba…

maya室内模型_C4d和3dmax、maya相比有什么优势?

C4D和3dmax、maya都是三维软件,功能都是非常的nice,很多新手小伙伴就在好奇它们有什么区别,对比之下,c4d有哪些优势?c4d和3dmax的主要应用领域就是区分它们的地方。C4D一般用于栏目包装,影视后期&#xff0…

HH SaaS电商系统的标签系统设计

文章目录打标规则公式打标公式变量修改标签删除标签标签实体标签与对象的关系标签和商品:标签和商城会员:标签和租户会员:打标规则公式 公式名称:近日销量创历史新高 规则公式:近$ {days}销量创历史新高 公式名称&a…

jvm高并发_在JVM上对高并发HTTP服务器进行基准测试

jvm高并发在第一篇关于HTTP客户端的文章 (我将您重定向到JVM上的高效HTTP的介绍)之后,现在让我们来谈谈HTTP 服务器 。 有一些关于HTTP服务器的基准测试,但通常受到诸如以下缺点的阻碍: 没有有效地执行高并发方案&am…

excel未完全加载怎么办_你知道如何改变Excel的打开姿势吗?

你是否曾经想过在启动Excel时自动打开某些特定的文档?当然,你永远都可以手动去打开任何一个文档,但是如果有那么一种可能,去每次省下那么几秒来自动完成这一操作,你会愿意尝试吗?今天,火箭君就和…

电商系统的售后模块设计

文章目录售后单实体方案一方案二服务类型可选售后服务判断规则退款类型售后截止时间金币和优惠券如何返还买家端订单列表的“售后按钮”逻辑说明服务端处理逻辑买家端操作“售后按钮”页面跳转逻辑商家管理后台订单列表的“售后处理”逻辑说明服务端处理逻辑商家端操作“售后处…

python中元组和列表转化_4.Python列表/元组/集合/字典

4.1 Python列表• 列表用 [ ] 标识,是Python 最通用的复合数据类型。• 列表用 [ ] 表示,列表具有可嵌套性4.1.1 Python列表截取• 列表可以使用 [头下标:尾下标] 截取相应的子列表, 从左到右索引默认 0 开始,从右到左索引默认-1开…

【WebRTC---源码篇】(十二)WebRTC/RTX协议

在SDP中可以查询到提前协商好的RTX信息 接受到RTCP NACK 重传RTX包,有效荷载前两个字节为原始seqnumber 如何知道重传的是哪个包 发送RTX

stackoverflow_Stackoverflow:您尚未发现的7个最佳Java答案

stackoverflow您可以在Stackoverflow上找到哪些最有趣的答案? Stackoverflow是开发人员的金矿。 它可以帮助我们找到遇到的特定问题的最有用答案,并且我们总是从中学习新事物。 在以下文章中,我们研究了最受欢迎的Java问题和答案&#xff0…

json请求 post vue_Spring Boot+Vueaxios异步请求数据的12种操作(上篇)

Java大联盟致力于最高效的Java学习关注Spring Boot Vue 前后端分离最核心的操作就是通过异步请求完成数据同步,这其中又可以分为很多种不同的情况,比如是 GET 请求还是 POST 请求?参数是普通变量还是 JSON?基于 RESTful 架构如何…

【WebRTC---源码篇】(十三)WebRTC/Pacer

pacer作用 NextSendTime Timestamp PacingController::NextSendTime() const {Timestamp now = CurrentTime();if (paused_) {return last_send_time_ + kPausedProcessInterval;}// If probing is active, that always takes priority.if (prober_.IsProbing()) {Timest…

全景视觉空间直线检测_视觉SLAM深度解读

近年来,SLAM技术取得了惊人的发展,领先一步的激光SLAM已成熟的应用于各大场景中,视觉SLAM虽在落地应用上不及激光SLAM,但也是目前研究的一大热点,今天我们就来详细聊聊视觉SLAM的那些事儿。视觉SLAM是什么?…

对象必须实现 iconvertible。_java面向对象最全入门笔记(通俗易懂,适合初学者)...

前言:面向对象的三大特征封装 (Encapsulation)继承 (Inheritance)多态 (Polymorphism)编程思想:面向过程:做某件事情都需要自己亲历亲为,按照步骤去完成面向对象:做某件事情不需要自己亲历亲为,只需指定特定的对象去完…

HH SaaS电商系统的结算系统设计

文章目录一、第三方卖家销售货款结算流程说明:销售货款结算逻辑流程图预期收入如何统计二、第三方卖家推广分销佣金结算佣金结算逻辑流程图逾期佣金收入如何统计三、采购货款结算租户采购货款结算流程说明商城采购货款结算流程说明店铺商家的采购货款结算流程说明四…