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

相关文章

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

一文详解Git中分支本地和远程删除的方法

《一文详解Git中分支本地和远程删除的方法》在使用Git进行版本控制的过程中,我们会创建多个分支来进行不同功能的开发,这就容易涉及到如何正确地删除本地分支和远程分支,下面我们就来看看相关的实现方法吧... 目录技术背景实现步骤删除本地分支删除远程www.chinasem.cn分支同步删除信息到其他机器示例步骤

在Golang中实现定时任务的几种高效方法

《在Golang中实现定时任务的几种高效方法》本文将详细介绍在Golang中实现定时任务的几种高效方法,包括time包中的Ticker和Timer、第三方库cron的使用,以及基于channel和go... 目录背景介绍目的和范围预期读者文档结构概述术语表核心概念与联系故事引入核心概念解释核心概念之间的关系