Java线上排错---反编译文件

强烈推荐一个大神的人工智能的教程:http://www.captainbed.net/zhanghan

【前言】

        有时候经常会遇到一些诡异的问题:明明在本地运行代码没有问题,服务器代码和本地一样,请求的参数和所连接的数据源

都一样为啥服务器上不行那?

        如果在测试环境我们可以进行远程调试(参考《idea远程调试》),但是线上应该如何排查?

        博主遇到很多次这种情况,最后确定都是由于服务器上代码并没有更新导致的,没有更新原因有很多种比如:运维的部署脚

本有问题,执行错误脚本等等;那么如何确定线上运行的代码和本地运行有差异那?       

【反编译神器】

        一、两种反编译方法:

               1、通过jd-gui查看class文件

               2、通过阿里云的在线分析诊断工具Arthas的jad在线反编译;

        二、两种方法使用的详细步骤

               1、准备工作:

                   (1)以SpringBoot工程为例,代码地址:https://github.com/dangnianchuntian/springboot

                   (2)以代码中的LombokController 为示例

                   (3)在Linux上对项目进行部署

                   (4)通过swagger对项目进行访问

Java线上排错---反编译文件

               2、通过jd-gui查看class文件,方法:

                   (1)登录服务器,找到项目启动jar包,并创建临时目录t

Java线上排错---反编译文件

                   (2)将启动jar包拷贝到临时目录t中,并进入临时目录t中

Java线上排错---反编译文件

                   (3)使用unzip命令对jar包进行解压

Java线上排错---反编译文件

                   (4)进入到相关目录中找到LombokController.class

Java线上排错---反编译文件

                   (5)将LombokController.class导出到本地

Java线上排错---反编译文件

                   (6)在本地用jd-gui打开文件(jd-gui绿色免安装版地址:链接https://pan.baidu.com/s/1tj3iPQX5UW2yHffM6nicNQ 
提取码:x8up)注:如果出现文件损坏或打开乱码,请用方法二进行查看。

Java线上排错---反编译文件

               3、通过阿里云的在线分析诊断工具Arthas的jad在线反编译,方法:

                   (1)官网下载Arthas https://alibaba.github.io/arthas/download.html

                   (2)在服务器中通过 java -jar arthas-boot.jar 启动Arthas

Java线上排错---反编译文件

                   (3)按序号(此处为1)进入到项目中,并执行jad com.zhanghan.zhboot.controller.LombokController 查看内容

Java线上排错---反编译文件

 

【总结】

        1、有了这两种查看源码方法,可以使我们快速定位到问题;

        2、遇到问题后不要钻牛角尖,要从多个维度去思考问题。