昨天測试人员和开发者都发现, 某新版本号有严重的bug.  群里已经開始嚷嚷了, 但没有谁知道是谁引入的问题。本来呢, 这个问题不应该是由我去定位, 但主管让我帮定位一下, 毕竟时间太紧急, 必须尽快解决, 開始的时候, 我还是有些压力的跟有经验的员工讨论后, 也没有比較好的办法, 所以, 仅仅能自己想办法了。为了方便叙述,
以下我会对实际场景进行抽象。

经我亲自验证发现, 100版本号绝对ok,  300版本号却有问题, 也就是说, 是这个之间的某个版本号引入了bug.   由于这个问题比較难以定位, 所以查看配置库的改动记录就成了当前唯一可行的办法。

可是, 细致重复看了这个区间的改动记录, 没有发现有可疑的异常情况, 所以仅仅能採取二分查找验证了, 仅仅是每次验证都至少要15-20分钟, 并且每个步骤都不能出错。问题是, 模块较多, 是回退某一模块还是回退全部模块呢? 依据bug的现象, 确实难以分析出出问题的模块所在。

怎么办? 我和另外一个有经验的员工首先分析了出问题可能性最大的两个模块, 昨天下午開始, 对当中的一个模块(第三方库)进行版本号回退測试, 没有发现有异常, 并且单一模块回退多了, 非常easy造成编译只是(其它模块不回退), 各种郁闷和苦逼啊 搞到凌晨还是没有搞出来, 好吧, 太累了, 先回家睡觉。

今天呢, 我必须单独搞定这个问题, 于是我对另外一个可疑模块进行回退測试(其余模块都採用最新代码和库)。 边回退, 边记录结果。我取这个可疑模块的第200个版本号进行測试, 发现ok,  这个时候, 就有点高兴了知道问题基本就锁定在这个模块了, 于是花了3个多小时进行二分回退验证, 搞了7, 8次吧, 最后锁定了改动引入问题的版本号,
铁证如山。结果查看改动记录后, 傻眼了, 该代码提交人只改了一个单词。 好吧, 尽管我不清楚问题的详细原因, 但我证据充分地定位到了问题, 让相应的人改动(最后他发现, 也确实有问题)。

二分版本号回退法是最无奈的办法。 哥们, 以后改动问题要注意啊, 不要引入新的问题搞我辛苦一大天, 还搞到凌晨。

最后,要强调一下: 定位问题, 思路非常重要, 不然搞几天都有可能搞不出来, 自己误导自己。  这次定位bug, 尽管过程非常繁琐非常苦逼,但还是非常开心的, 定位出了一个严重的bug, 能让版本号顺利公布。

噢耶

补充说明: 有的网友反馈, 你能够加日志定位啊。 事实上, 原bug的现象就是: 该系统没有日志输出

无奈而又苦逼的二分版本号回退法定位新引入的bug!!!的更多相关文章

  1. 漫画 | 到底是什么让IT人如此苦逼???

    写在最后 漫画是有点夸张,不过多少还是有点现实开发过程的影子! 老板很乐观,核心就是三个月上线,至于怎么办那是底下人的事. 产品很无奈,心里盘算着,万万不可在他这一环节耽误了进度,时间这么赶,先出个壳 ...

  2. 从苦逼到牛逼,详解Linux运维工程师的打怪升级之路

    做运维也快四年多了,就像游戏打怪升级,升级后知识体系和运维体系也相对变化挺大,学习了很多新的知识点. 运维工程师是从一个呆逼进化为苦逼再成长为牛逼的过程,前提在于你要能忍能干能拼,还要具有敏锐的嗅觉感 ...

  3. Pylons安装苦逼之路

    本文介绍一下我在安装pylons的过程中出现的一些错误和解决办法,当然这些都是不完全版. 1.在Serve1(服务器Python版本2.4.3)上面装环境的时候总是出现with_statement有关 ...

  4. PHP项目的“苦逼”经历与思考

    PHP项目的"苦逼"经历与思考 PHP零基础.但因为项目人手不够的原因,被安排到一个用户"定制"项目. 该项目是用PHP生成的统计数据报表. 而用户又有新的3个 ...

  5. 搞IT的技术人员为什么会如此苦逼

    http://www.cnblogs.com/springmvc-hibernate/archive/2012/05/10/2493733.html ————————————————————————— ...

  6. 谋哥:App开发者的苦逼不值得怜悯!

    [谋哥每天一干货,第四十篇]        为什么取这个标题呢?因为昨天一些本来“支持”谋哥的人看到谋哥搞收费VIP群,觉得谋哥赚苦逼开发者的钱很不道德,且说谋哥我写的东西都不切实际,全部是一些思想性 ...

  7. 苦逼三流小公司程序员这半年找工作经历(3)——选择offer

    本文按照企业规模.性质.规模,分成三类,点评一下遇到的这些公司.也算是为半年找工作经历的一个总结. 1,三流小公司 公司规模类似于笔者跳槽前所在企业,性质有外商独资.合资,当然大多数都是民营企业,规模 ...

  8. 苦逼IT才能看懂的笑话

    这是苦逼IT才能看懂的笑话1.栈和队列的区别是啥? 吃多了拉就是队列:吃多了吐就是栈 2.世界上最遥远的距离不是生与死,而是你亲手制造的BUG就在你眼前,你却怎么都找不到她... 3.<c++程 ...

  9. 你还在苦逼地findViewById吗?使用ButterKnife从此轻松定义控件

    前段时间笔者在苦逼地撸代码~最后发现有些复杂的界面在写了一屏幕的findviewbyid~~~另一堆setOnXXXListener~有没有方便一点的方法让我们简单点不用每次都定义一次.find一次, ...

随机推荐

  1. poj 1220 NUMBER BASE CONVERSION(短除法进制转换)

    题目连接:1220 NUMBER BASE CONVERSION 题目大意:给出两个进制oldBase 和newBase, 以及以oldBase进制存在的数.要求将这个oldBase进制的数转换成ne ...

  2. Java中的工具类和新特性

    1:Collections集合框架工具类: /* 集合框架的工具类. Collections:集合框架的工具类.里面定义的都是静态方法. Collections和Collection有什么差别? Co ...

  3. CV和Resume的区别(转)

    常常有人把CV和Resume混起来称为“简历”,其实精确而言,CV应该是“履历”,Resume才是简历.Resume概述了有关的教育准备和经历,是对经验技能的摘要:curriculum vitae则集 ...

  4. UltraEdit破解方法最强收录

    作为一个能够满足你一切编辑需求的强大文本编辑器.ultraedit在IT届有着非常高的人气.只是它正版的价钱也是不廉价滴,没记错的话是要好几十刀. 那么对于我们来说,破解UltraEdit就是一项必备 ...

  5. BGP协议学习总结

    BGP学习总结 BGP是目前使用的唯一的自治系统间的路由协议,它是一种矢量路由协议,基于TCP的179号端口,它采用单播增量更新的方式更新路由,与其他的路由协议不同的是,BGP只要TCP可达,就可以建 ...

  6. php 汉字转拼音 [包含20902个基本汉字+5059生僻字]

    原文:php 汉字转拼音 [包含20902个基本汉字+5059生僻字] 昨天在转换拼音的时候发现个bug,有好多字都无法转换,不过也不能怪他,毕竟人家的库才8k,应该只有常用的.无奈上网找了下,发现一 ...

  7. c++ 对象指针参数和对象引用参数02

    对象指针作为函数参数和对象引用作为函数参数都比对象作为函数参数要用的更为普遍 传对象指针和传对象引用作为实参,那么实参在函数里发生了变话,那么相应的对象本身也会发生变化,二传递对象本身作为实参的话,实 ...

  8. Unity3D开发一个2D横版射击游戏

    教程基于http://pixelnest.io/tutorials/2d-game-unity/ , 这个例子感觉还是比较经典的, 网上转载的也比较多. 刚好最近也在学习U3D, 做的过程中自己又修改 ...

  9. 修ecshop品牌筛选以LOGO图片形式显示

    如何实现商品列表页属性筛选区品牌筛选以LOGO形式展示,最模板总结ecshop/'>ecshop教程入下: 1.修改 category.php 文件,将(大概215行) $sql = " ...

  10. windows phone 独立存储空间的操作 (2)

    原文:windows phone 独立存储空间的操作 (2) IsolatedStorage独立存储空间是保存应用程序的一些数据已经配置文件,独立存储空间相对于其他的wp程序是独立的,也就是说每个wp ...