bug调试技巧

宝典之一 : 坚信一个原则,程序不会说谎,一定是有原因的

多数的错误表现看起来莫明奇妙,甚至不可思议

但当我们找到问题后会发现:其实问题的根源是如此简单、如此的合乎道理。

这就要求我们:

1、保持一种淡定的心态,耐心地来查找问题

2、仔细看日志:

对着满屏幕的英文错误日志,不要慌,不认识的单词慢慢翻译,一定要仔细查找问题最初抛出的日志关键描 述。

3、善于分析关键字

大部分的错误互联网上是有解决方案的,但因为搜索关键字的选择错误,导致这些解决方案不被我们看到。

一定要善于在错误日志种分析出关键的那几个“错误字眼”

4、相信谷歌比百度更容易找到答案

宝典之二:链路大法

程序系统,就像一张复杂的电路网,程序的调用、数据传递过程,就像电流在电路流转。

当这张网出问题时,我么顺着链路一点点的查找,总能找到问题点根源。

我们拿一个简单的链路来举例:

假设现在灯泡不亮了,面临这样一个链路,在没有任何调试数据时,我们可以说整个链路都可能是有问题的:

(用红色表示有问题的链路)

那么我们调试的方案如下:

1、从起点开始:调试是否有电?

把正负极连接一个没有问题的灯泡(绿色表示确定没问题):

首先我们得找一个没有问题的灯泡来调试,如果这时还不亮,那说明电源有问题。

2、如果电源没问题,我们再调试A点:

依次如上调试,最终我们肯定能确定问题根源。


我们把电路更换为程序链路来看一下:

同理,从入口调试开始,先调试Nginx有无问题:

同样地,我们需要先建立一个“确信点”,就像那个“没问题的灯泡”,对于nginx来讲,我们可以建立一个最简单的server来调试:

如果确定nginx没问题,我们再依次确认A、B有无问题,有时模块的调用无法全链路调用调试,比如问题只发生在A掉B的时候,这时候curl,telnet就是我们有力的工具了,这个时候细展开链路可能会是这样子的:

我们无法确认是B服务有问题了,还是k8s网路服务有问题了,此时我们可以在服务B中通过curl请求自己来确认:

curl http://localhost:8080/api/xxx

  

总之,链路大法的关键是要找一个“没有问题的灯泡”去调试某个链路点,比如建立简单的nginx server节点、curl、ping等等,

通过一个我们确认没有问题的方法,一个个去排查链路上的问题。

宝典之三:不要相信自己的猜测,眼见为实

抛弃“我以为、我觉得、我猜测”

即使是你认为没问题的链路点,也一定要亲自调试,亲眼见到才确定


易族智汇(javashop)原创文章

bug调试宝典的更多相关文章

  1. geotrellis使用(七)记录一次惨痛的bug调试经历以及求DEM坡度实践

    眼看就要端午节了,屌丝还在写代码,话说过节也不给轻松,折腾了一天终于解决了一个BUG,并完成了老板安排的求DEM坡度的任务,那么就分两段来表. 一.BUG调试 首先记录一天的BUG调试,简单copy了 ...

  2. geotrellis使用(十二)再记录一次惨痛的伪BUG调试经历(数据导入以及读取瓦片)

    Geotrellis系列文章链接地址http://www.cnblogs.com/shoufengwei/p/5619419.html 目录 前言 BUG还原 查找BUG 解决方案 总结 后记 一.前 ...

  3. 最难忘的Bug调试经历

    摘要:目前,著名的社区问答网站Quora上出现一个很火的讨论:你调试过最难的Bug是什么?大家纷纷留言,把自己最痛苦的一次调试经验写下来. 相信每位程序员都有过一段不堪回首地Bug调试经历,程序员一听 ...

  4. 论 BUG调试与(程序猿)初学者

    作为一枚程序猿,BUG调试是最基本的技能,对于初学者更是重中之重.个人而言,要想为自己的程序猿生涯更上一层楼,就得知道什么是BUG调试,而且还必须知道怎么调好BUG.那么BUG究竟是什么呢?在我之前的 ...

  5. Bug调试(lldb)

    原文网址:http://www.cnblogs.com/Twisted-Fate/p/4760156.html 今天博主有一些Bug调试的需求,遇到了一些困难点,在此和大家分享,希望能够共同进步. X ...

  6. 记一次 springboot 参数解析 bug调试 HandlerMethodArgumentResolver

    情况描述 前端输入框输入中文的横线 -- ,到后台接收时变成了 &madsh;$mdash 正常应该显示成这样: bug调试思路记录 最开始完全没有向调试源码方面想,试了不少方法,都没解决,没 ...

  7. 13 年的 Bug 调试经验总结

    在<Learning From Your Bugs>一文中,我写了关于我是如何追踪我所遇到的一些最有趣的bug.最近,我回顾了我所有的194个条目(从13岁开始),看看有什么经验教训是我可 ...

  8. <转载>linux下内存泄露查找、BUG调试

    先收藏着,抽空好好看看:http://www.ibm.com/developerworks/cn/linux/l-pow-debug/ 简介 调试程序有很多方法,例如向屏幕上打印消息,使用调试器,或者 ...

  9. 13 年的 Bug 调试经验总结(来自蜗牛学院)

    在<Learning From Your Bugs>一文中,我写了关于我是如何追踪我所遇到的一些最有趣的bug. 最近,我回顾了我所有的194个条目,看看有什么经验教训是我可以学习的.下面 ...

随机推荐

  1. SSM框架之Spring(4)AOP

    Spring(4)AOP 1.AOP概述 在软件业,AOP为Aspect Oriented Programming的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种 ...

  2. NumPy实现数据的聚合,计算最大值,最小值

    1.数组值的求和 首先构造一个具有100个值的数组,然后我们利用两个不同的方法进行求和: >>> l=np.random.random() l的数据如下: >>> ...

  3. Android studio将一个项目作为module导入另一个项目

    有两个Android项目,一个为pozhudl,一个为app,现在欲将pozhudl项目作为module导入到app中,并调用pozhudl项目中的类 先在pozhudl项目的build.gradle ...

  4. 漏洞扫描与分析-Nessus-8.7.2最新版-安装-部署-使用

    漏洞扫描与分析-Nessus 2019/10/10 Chenxin 简介 官网 https://zh-cn.tenable.com/ 产品 https://zh-cn.tenable.com/prod ...

  5. Playbook剧本小结

    1.Playbook剧本小结 1.什么是playbook,playbook翻译过来就是"剧本",那playbook组成如下 play: 定义的是主机的角色task: 定义的是具体执 ...

  6. platform平台device和driver如何匹配【转】

    转自:https://www.cnblogs.com/sky-heaven/p/6869591.html 版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接 ...

  7. 一、itk在VS2019上面的安装 和例子(HelloWorld)运行

    一.Itk简介 vtk是专门用于医疗图像处理的函数库,类似opencv. 这篇博客主要是讲解安装vtk之后的例子的运行,即如何构建自己的第一个ITK例子 二.Itk安装 Itk安装参考这篇博客: ht ...

  8. Day5- Python基础5 模块导入、time、datetime、random、os、sys、hashlib、json&pickle

    本节目录: 1.模块的分类 2.模块的导入 3.time模块 4.datetime模块 5.random 6.os模块 7.sys模块 8.hashlib 9.json&pickle 一.模块 ...

  9. vscode笔记

    一.修改操作栏字体 https://www.cnblogs.com/liuyangfirst/p/9759966.html 1.代码改写,进入默认安装的如下路径,搜索workbench 2.用Vs c ...

  10. VUE 实现监听滚动事件,实现数据懒加载

    methods: { // 获取滚动条当前的位置 getScrollTop() { let scrollTop = 0 if (document.documentElement && ...