bug复现不了开发人员不解决,遇到疑难bug该如何排查 ,这两个方法你需要知道。

本文主要是介绍bug复现不了开发人员不解决,遇到疑难bug该如何排查 ,这两个方法你需要知道。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在测试的时候,有时候经常会遇到一些难以复现的bug ,比如有的线上bug在少部分用户哪里出现,但是自己复现却是没有问题的 ;亦或者是在测试环境上发现了一个偶现bug ,然后再复现就很难以找到了 ;亦或者是出现一个技术问题 ,像环境部署,明明部署的是没有问题,按照正确的步骤来的,但是就是无法访问系统。

那么,像这类问题它都属于恢复性问题 ,就是正常情况下 ,它都是没有问题的 ,但是在操作的过程中产生了某些微小变化导致了问题的产生。如果没有发生任何变化 ,则情况就保持不变 。这类问题往往需要找到问题产生的根因 ,也就是这个微小的变化在哪 ?所以这个微小的变化是分析问题根因的一个很重要因素 。

接下来介绍的两种方法,都可以有效的找到问题原因 。它们分别是:构成条件法差异对比法

1.构成条件法

所谓的构成条件法 ,就是一个功能要完成正常的操作,它所需要的构成条件,这些条件都是必要的,如果有一个条件不具备,那么该功能就无法完成 。就比如通过xshell连接Linux服务器的功能。若正常情况下,只要有正确的连接信息 ,你都能连接正常 。但是就是这个简单连接操作 ,也依然会出现连接失败的情况 ,连接失败你也未必找到具体的原因。

就以上面的案例我们通过构成条件法来分析下 ,首先想要成功连接到服务器 ,就必须具备两个条件 :

  1. 必须要有正确的连接信息 ,

  2. 网络的连通性

以上两个条件缺一不可 ,那如果连接失败 ,我们就可以对这两个条件逐一去排查 。

首先我们再次确认连接信息输入的是否正确 。

  • 连接的用户名和密码是否正确 ,因为有时候系统已经修改了密码导致了连接失败 ,但是你不知道。

  • 连接ip地址是否正确 ,比如有的系统ip地址突然发生变化了 ,你还是那之前的ip进行连接,那肯定失败了 。

  • 端口号 ,这个一般不会变 ,不过也可以检查下 。

通过以上的排查 ,你可能已经找到了问题的答案(原因) ,当然也可能排查了上面的情况但问题依然存在,那这种情况就继续往下排查 。接下来就排查网络的连通性 ,造成连通性不通的情况也可能有如下情况 ,可以进行逐一排查 。

  • 网络是否联网 ,因为有的时候,网络中途断开 ,我们也是不知道 ,这个时候可以先排查下网络 。

  • 检查防火墙是否启用 ,如果启用了防火墙 ,可以关闭或者加通行策略 。

通过以上的排查 ,你可能已经找到了问题的答案(原因) ,当然也可能排查了上面的情况但问题依然存在。

无论排查结果如何 ,通过条件分析法,就是通过分析它的构成条件,然后看它的构成的构成条件是否因为外部因素而发生了改变 。

如果此方法不能排查出问题的话 ,那么接下来就可以考虑下面的方法 。

2.差异对比法

所谓的差异对比,就是通过和正常的条件/环境进行比较 ,找出它们之间的差异 ,从差异中在分析可能产生的原因,然后再进行验证 。

同样还是上面的案例 ,通过使用差异法进行比对的话 ,那么就是找一套好的环境或者没有问题的链接和它进行相比较 ,试图找出差异 ,具体如下 。

观察到的现象比较对象说明验证
xshell连接服务端失败使用同一台机器的putty连接正确若还有问题说明主要问题还是xshell客户端的操作的 。而且证明网络也没问题
本机的xshell连接失败其它同学的xshell能正确链接若还有问题说明只针对个人的xshell是有问题的 ,接下来验证正确xshell和有问题xshell的版本,安装方式等,
本机的xshell连接失败相同版本的xhsell进行安装若还有问题说明不是xshell的版本有问题 ,可能保存的配置有问题 ,尝试清除这些配置重新尝试
本机的xshell连接失败删除配置后重新连接若还有问题说明已经不是配置文件导致的了 ,接下来去理解xshell连接的内部逻辑 ,确定内部的连接步骤 。

在这个比较的过程中,你会发现一个现象,通过一个能正常操作的比较对象 ,然后一步步去进行比对 ,每进行一次比对都能排除一些原因 ,然后再找新的比对对象 ,它的范围往往会更小 。也就是说每比对一次,范围会缩小一次 ,但是越往后越难去找新的比对对象,因为越往后就越涉及到具体的细节了,往往都是你看不到的东西 。想要搞清楚,你甚至要理解软件内部的业务逻辑 。

3.总结

通过以上的方法,可以大大的提高了我们定位问题的能力 ,但是有些问题已经涉及到了个人的技术知识盲区了,很多出错的原因都是我们压根就不知道的 。 所以,你最好还要结合百度来一起排查 ,尽量扫清你的知识盲区 。

最后 ,我们总结一下 ,针对一些难以复现的bug或者遇到的技术问题 ,找到根本原因很重要 。可以通过以下的思路进行开展 。

  1. 描述具体问题 ,通过不同的方法(构成条件法和差异比对法)来进行分析可能存在的原因(假设)

  2. 进行验证假设 ,如果验证结果符合你的预期 ,那么根因也就找到了 ,到这里就结束了。如若还不符合你的预期,继续新的假设,继续验证 。依次循环此过程 。

  3. 总结原因并复盘分析过程 ,为下次分析提供一些经验 。

这篇关于bug复现不了开发人员不解决,遇到疑难bug该如何排查 ,这两个方法你需要知道。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/812118

相关文章

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

如何解决线上平台抽佣高 线下门店客流少的痛点!

目前,许多传统零售店铺正遭遇客源下降的难题。尽管广告推广能带来一定的客流,但其费用昂贵。鉴于此,众多零售商纷纷选择加入像美团、饿了么和抖音这样的大型在线平台,但这些平台的高佣金率导致了利润的大幅缩水。在这样的市场环境下,商家之间的合作网络逐渐成为一种有效的解决方案,通过资源和客户基础的共享,实现共同的利益增长。 以最近在上海兴起的一个跨行业合作平台为例,该平台融合了环保消费积分系统,在短

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo