您现在的位置是:首页 > 技术人生 > 后端技术后端技术

记一次开发环境和本地环境不同导致问题的解决Cannot find the system Java compiler

高晓波2020-02-16【后端技术】人已围观

简介问题:logService为系统的日志记录服务,利用切面记录其他各服务调用情况、也包括一些业务的处理,如商品上架记录至动态表等;出现的问题是商品上架等过程执行完成后,动态表未能正常

问题:

logService为系统的日志记录服务,利用切面记录其他各服务调用情况、也包括一些业务的处理,如商品上架记录至动态表等;

出现的问题是商品上架等过程执行完成后,动态表未能正常入库数据。


解决过程:

1、首先看代码,由于主键生成器的更改,入库对象没使用最新的主键生成策略,加上-->本地测试-->通过;

2、线上开发环境问题依旧存在,OK,加点日志,追踪线上代码执行过程;

3、线上日志打印太快且乱,发现logService代码中多处利用线程池多线程调用,百度IDEA多线程debug方案:断点处右击,suspend选择all,添加condition,如下图:



找到需要拦截的线程后,代码打日志也加上过滤条件;其中,怀疑过多线程导致问题,后缕清代码发现并无不妥;

4、线上代码执行到某处后中断,然后本地此处是正常执行的;猜测线上maven私服和本地使用maven私服某些jar包不同导致(本地环境使用的maven私服和线上使用的maven私服为不同私服);遂,将本地代码打包编译单独上传至主机上启动运行,问题依旧存在;

5、将线上jvm内存由512M改为1024M,问题依旧存在;

6、尝试利用jstate查看jvm内存状态,报jstate命令不存在,查看jdk版本,为openJDK1.8;

7、改写代码,逻辑未变,仅调用方式,初始化等做调整,上传、运行、报错:

Exception in thread "main" java.lang.IllegalStateException: Cannot find the system Java compiler. Check that your class path includes tools.jar

此时问题终于浮出水面,openJDK lib目录中缺少tools.jar,上传完整版jkd1.8至主机,解压,配置环境变量,启动,测试,完美;

8、测试没问题后,运行jenkins编译发布任务,再次测试,问题又出现;经反复尝试,检查启动脚本,发现jenkins启动用的还是原来的openjdk,卸载openjdk,问题解决;

9、至此,两天过去了;

 

总结:

1、相同的代码,在不同环境下运行出现问题,99%问题出在环境不一致,可能是数据环境,可能是运行环境等等;

2、此次问题耗费大量时间定位,因为原代码结构没能正确的将错误堆栈打印,表现为一切正常、无报错,掩盖掉报错日志即挖了个深坑;

Tags:java

很赞哦! ()

文章评论