一、背景
因为其他研发部门同事给的产品jar包存在一个问题,就是http底层的超时时间默认为60s,但是最近调用外部接口同步数据,这个数据量太大导致超时超过60s,每次同步都不成功。但是客户目前对此情况特别不满意,需要紧急处理。
其实很简单的逻辑就是,将超时时间60s先延长,后续再优化产品。奈何研发这个产品的同事又被其他项目拖住了,腾不出时间来解决。因为源码在他那边,我们也无法修改进行编译。
最后和他远程看了下锁定是哪个类,在哪个类修改即可。 无奈,我们为了紧急解决用户的问题,想到了使用Arthas对哪个class类进行反编译,最后热加载这个class即可完成替换。
二、Arhas的操作过程
1、arthas连接attach进程
java -jar arthas-boot.jar
选择对应的进程id输入,回车,进入arthas dashbord界面
2、jad反编译生成java源码文件
jad --source-only com.demo.HttpClientConfig > /data/HttpClientConfig.java
将这个类com.demo.HttpClientConfig反编译生成java源代码文件, 对代码修改超时时间
3、mc重新编译这个class
mc /data/HttpClientConfig.java -d /data/tmp/arthas/
重新编译/data/HttpClientConfig.java生成到/data/tmp/arthas/目录下
4、备份jar包的旧class,替换新的class
解压jar包:
jar xf $file.jar
备份jar包的旧class,替换新的class,重新打包:
jar cf $file.jar -C ./ .
5、寻找割接窗口,将此机器流量切走,重启,观察
申请割接窗口,先从LB将流量切走,安全的重启、观察程序是否正常, 滚动更新,最后观察,程序可以正常同步,不会因为60s超时导致同步失败
三、可视化查看Java反编译工具(JD-GUI)
项目地址: https://java-decompiler.github.io/
针对Java项目可以使用JD-GUI针对jar包进行反编译, 可以具备一些参考功能。
四、总结
Artahs除了可以做这些trace、watch, 其实jad、mc这些命令也是很强大的。 这某些特殊情况下可以使用反编译、重新编译来解决特殊情况.