2019-01-02 14:05

  毕业时写了一段时间的C,那时候调试使用gdb,后来转了java,当时就想java程序怎么调试,找了一下,果然,那就是jdk自带的jdb

  windows里是这样的

       1546407750348027.png

  Linux下是这样的

       1546407798507510.png

  一般我在linux下来调试Java程序

  好,那么,问题来了,这玩意怎么用?有好几种玩法

  第一种玩法:以经典的HelloWorld为例,先写一个Java程序,如下:

       1546407874127841.png

  我们把编译好的类上传到linux下,如下所示

       1546408045539706.png

  务必强调一下:类所在的包名的层次结构也要在linux下体现出来

  下面我们来玩起来,在linux下操作如下

       1546408086458734.png

  程序顺利debug,每次都输出当前的位置,就是line=5 这样的,也可以使用where来查看当前的线程栈,如下所示

       1546408134210883.png

  好,到这里,入门完成,读者可能一脸懵逼,debug过程中没法看到源码啊,这是因为我们只有class,没有java文件

  下面我们把java文件上传上来,可以上传到任何一个目录,只要后面正确指定就行了,创建一个文件夹

       1546408175332560.png

  然后按照层次结构把源码上传上来

       1546408224104092.png

  让我们重新组织下jdb的h3cne命令如下

       1546408371235271.png

  开心吗?简单的debug就可以进行了

  有的同学说我有很多jar,不是类,这也是可以的,自己多尝试一下,没有问题,碰到问题百度下

  上面是通过jdb来启动一个程序,也有一种情况是程序在linux上跑得好好的,我想去调试的时候去调试,不想调试的时候让它自己运行不去打扰它

  以我最近调试的flink为例,ps -ef一把看一下

       1546408413803820.png

  程序启动的命令行里加上这些参数,然后怎么使用呢?在你想要去debug它的时候,使用下面的命令

       1546408476571458.png

  这个时候,华三认证,jdb已经跟目标进程建立了关系,因为断点还没有触发,所以我们什么都看不到,我们尝试来发送一条消息到kafka来触发这个断点的hit

       1546408551647858.png

  顺利命中,这里没有源码出现,是因为我没有放源码,我是在本地eclipse里打开java代码对比着看,读者也可以上传到linux下来玩,方法上面已经说过了

  执行一把where看详细的当前位置

       1546408598164241.png

  时刻提醒你是谁,你在哪,你在干什么,别迷失了方向,迷茫的时候就执行一把where就会找到新的方向

  这种方式不用指定class在哪,因为我们是连接到进程来实现debug,进程都起来了,也不用担心class的识别了

  好,简单的debug其实已经可以了,下面讲一下jdb的命令有哪些

  读者可以在实践中来掌握这些命令的使用

  当你把所有源码都debug完一遍的时候,相信我,你的巅峰之路就开始了!

      出处:强子1985

评论