启动错误分析以及解决方法

下图为启动报错信息
WX20171009-154104.png

红色框选中位置是真正错误原因,接下来,查看java.net.URL类,发现(如下图红框中代码)
1507535315897.jpg
只要factory存在,就会抛出异常,猜想可能是由于已经有某个类创建了factory
通过查看文档,发现TomcatURLStreamHandlerFactory.disable()方法表示不使用默认的Tomcat中创建的factory,这里也验证了是由于已经有其他类创建了factory
通过debug,发现redisson(redis的第三方客户端jar,与jedis功能类似)在创建RedissonClient类时,执行如下方法
WX20171009-155650.png
上图是在Config.fromYAML(…)->new ConfigSupport()->URLBuilder.init()中发现,很明显可以看出,在执行init时,会先把factory置空,然后再新创建一个factory,但是Tomcat创建factory时,没有置空,所以出现了冲突问题。
目前测试中,暂未发现加上TomcatURLStreamHandlerFactory.disable()后会出现其他问题。

原创文章,转载请注明出处。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐