一、异常现象
他们程序在本地通过java形式直接跑起来的时候,是正常的。
但是测试服务器上,程序跑到一半就不继续往下走了,而且,也不报错,日志里面没有任何信息。
二、异常解决
1.核心思想
抽丝剥茧,层层逼近。缩小bug出现的范围。
2.异常解决过程
2.1 反编译jar包
使用jd-gui反编译jar包(A),复制反编译后的class文件里的内容
2.2 修改java文件
在eclipse中新建一个工程,新建一个java类,类名和class文件名称一致,将class文件的内容粘贴进来
然后再修改java文件的内容。这里主要是增加一些打印语句
2.3 eclipse打jar包
通过eclipse将2.2中的工程打成一个jar包(B),用解压工具(如好压)解压
再将原本的jar包(A),用解压缩工具解压得到文件夹C。
将修改后class文件替换掉文件夹C中的class文件
2.4 命令行打jar包
从命令行进入到文件夹C,执行打包命令:
jar -cvf bbb.jar * //将文件夹C中的所有文件打包进bbb.jar
2.5 替换jar
将修改后的jar包替换掉原工程中的jar包。
2.6 得到结果
反复执行以上操作,发现最终出现问题的地方是:
MongoClientURI uri = new MongoClientURI(this.mongoUri, new MongoClientOptions.Builder().connectionsPerHost(connectionsPerHost).serverSelectionTimeout(serverSelectionTimeout));
程序执行到这里就不继续往下执行了,然后可以发现 MongoClientURI 这个类是 mongoDB的。那么可能是mongoDB出问题了。
是什么问题呢?为什么本地是正常的,但是测试服务器上就出异常了呢?这两个地方mongoDB 有什么不同吗?
然后去测试服务器上看看,发现测试服务器上mongoDB的驱动有两个。
那么是不是因为jar包冲突导致的呢?删掉一个试试,发现程序正常了
三、参考资料