1、解决sonar-checkstyle-plugin运行过程中出现的异常问题
2016-07-22 00:00
246 查看
摘要: 解决sonar-checkstyle-plugin运行时,报java.lang.NoSuchMethodError: com.google.common.io.Closeables.closeQuietly(Ljava/io/InputStream;)异常的问题。
checkstyle: 6.12.1
sonar-checkstyle: 2.5-SNAPSHOT
checkstyle-all : 2.5-SNAPSHOT
sonar-checkstyle-plugin: 2.5-SNAPSHOT
sonar-checkstyle插件中,引用了checkstyle和sonar-plugin-api两个jar包,这两个jar包都引用了guava,但是版本不一样,checkstyle使用guava 18.0,sonar-plugin-api使用guava 10.0.1。对于类 com.google.common.io.Closeables ,guava 18.0不兼容10.0.1【假如在pom文件中不指定guava版本的话,默认是用高版本】。sonar-checkstyle是通过maven的shade插件来解决guava版本不兼容的问题,具体做法:在sonar-checkstyle项目中建立checkstyle-all项目中通过【maven-shade-plugin】插件,将checkstyle中的guava18.0包合并到checkstyle包【com.puppycrawl.tools.checkstyle.guava】路径下,并重新生成【checkstyle-all-2.5.2-SNAPSHOT.jar】包来替代checkstyle-6.12.1,在真正的sonar-checkstyle插件项目sonar-checkstyle-plugin中引用的 checkstyle-all,是来解决guava冲突的问题。
但是,由于 checkstyle-all 引用了checkstyle,导致 sonar-checkstyle-plugin间接引用了checkstyle,打包的时候,仍然将checkstyle打包进入 sonar-checkstyle-plugin的jar包。 类加载的时候依然加载的是 checkstyle,而不是替换checkstyle和guava18.0的 checkstyle-all,所以并没有真正解决guava版本不兼容的问题。
配置如下:
一、版本说明
sonar版本:5.6checkstyle: 6.12.1
sonar-checkstyle: 2.5-SNAPSHOT
checkstyle-all : 2.5-SNAPSHOT
sonar-checkstyle-plugin: 2.5-SNAPSHOT
二、问题现象和问题描述
代码质量配置中添加checkstyle规则后,在执行代码检查时,报如下异常,导致检查中断:Exception in thread "main" java.lang.NoSuchMethodError: com.google.common.io.Closeables.closeQuietly(Ljava/io/InputStream;) at com.puppycrawl.tools.checkstyle.PackageNamesLoader.getPackageNames(PackageNamesLoader.java:156) at com.puppycrawl.tools.checkstyle.Checker.finishLocalSetup(Checker.java:137) at com.puppycrawl.tools.checkstyle.api.AutomaticBean.configure(AutomaticBean.java:134) at org.sonar.plugins.checkstyle.CheckstyleExecutor.execute(CheckstyleExecutor.java:84) at org.sonar.plugins.checkstyle.CheckstyleSensor.analyse(CheckstyleSensor.java:57) at org.sonar.batch.phases.SensorsExecutor.executeSensor(SensorsExecutor.java:58) at org.sonar.batch.phases.SensorsExecutor.execute(SensorsExecutor.java:50) at org.sonar.batch.phases.AbstractPhaseExecutor.execute(AbstractPhaseExecutor.java:83) at org.sonar.batch.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:189) at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142) at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127) at org.sonar.batch.scan.ProjectScanContainer.scan(ProjectScanContainer.java:265) at org.sonar.batch.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:260) at org.sonar.batch.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:258) at org.sonar.batch.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:250) at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142) at org.sonar.batch.scan.ProjectScanContainer.startComponents(ProjectScanContainer.java:128) at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127) at org.sonar.batch.task.ScanTask.execute(ScanTask.java:55) at org.sonar.batch.task.TaskContainer.doAfterStart(TaskContainer.java:86) at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142) at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127) at org.sonar.batch.bootstrap.GlobalContainer.executeTask(GlobalContainer.java:124) at org.sonar.batch.bootstrapper.Batch.executeTask(Batch.java:119) at org.sonarsource.scanner.api.internal.batch.BatchIsolatedLauncher.execute(BatchIsolatedLauncher.java:62) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) at java.lang.reflect.Method.invoke(Unknown Source) at org.sonarsource.scanner.api.internal.IsolatedLauncherProxy.invoke(IsolatedLauncherProxy.java:60) at com.sun.proxy.$Proxy0.execute(Unknown Source) at org.sonarsource.scanner.api.EmbeddedScanner.doExecute(EmbeddedScanner.java:240) at org.sonarsource.scanner.api.EmbeddedScanner.runAnalysis(EmbeddedScanner.java:151) at org.sonarsource.scanner.cli.Main.runAnalysis(Main.java:110) at org.sonarsource.scanner.cli.Main.execute(Main.java:72) at org.sonarsource.scanner.cli.Main.main(Main.java:60)
三、原因
未完全解决guava版本不兼容的问题。具体原因如下:sonar-checkstyle插件中,引用了checkstyle和sonar-plugin-api两个jar包,这两个jar包都引用了guava,但是版本不一样,checkstyle使用guava 18.0,sonar-plugin-api使用guava 10.0.1。对于类 com.google.common.io.Closeables ,guava 18.0不兼容10.0.1【假如在pom文件中不指定guava版本的话,默认是用高版本】。sonar-checkstyle是通过maven的shade插件来解决guava版本不兼容的问题,具体做法:在sonar-checkstyle项目中建立checkstyle-all项目中通过【maven-shade-plugin】插件,将checkstyle中的guava18.0包合并到checkstyle包【com.puppycrawl.tools.checkstyle.guava】路径下,并重新生成【checkstyle-all-2.5.2-SNAPSHOT.jar】包来替代checkstyle-6.12.1,在真正的sonar-checkstyle插件项目sonar-checkstyle-plugin中引用的 checkstyle-all,是来解决guava冲突的问题。
但是,由于 checkstyle-all 引用了checkstyle,导致 sonar-checkstyle-plugin间接引用了checkstyle,打包的时候,仍然将checkstyle打包进入 sonar-checkstyle-plugin的jar包。 类加载的时候依然加载的是 checkstyle,而不是替换checkstyle和guava18.0的 checkstyle-all,所以并没有真正解决guava版本不兼容的问题。
四、解决办法
sonar-checkstyle-plugin项目在引用checkstyle-all的时候,排除引用checkstyle,又通过引用scope级别为provided的checksytle包,来避免运行时无法通过编译的问题。配置如下:
<dependency> <groupId>${project.groupId}</groupId> <artifactId>checkstyle-all</artifactId> <version>${project.version}</version> <!--排除原生的checkstyle软件--> <exclusions> <exclusion> <groupId>com.puppycrawl.tools</groupId> <artifactId>checkstyle</artifactId> </exclusion> </exclusions> </dependency> <!--引用checkstyle软件,仅供编码使用--> <dependency> <groupId>com.puppycrawl.tools</groupId> <artifactId>checkstyle</artifactId> <version>${checkstyle.version}</version> <!-- 依赖jdk或容器提供 --> <scope>provided</scope> </dependency>
相关文章推荐
- 解决Mysql服务器启动时报错问题的方法
- android @override 报错解决方案
- 编译PHP报错configure error Cannot find libmysqlclient under usr的解决方法
- Vue.js报错Failed to resolve filter问题的解决方法
- flash 报错捕获(Catch All Exception in Flash)
- Eclipse引入jquery报错如何解决
- javascript在myeclipse中报错的解决方法
- Android启动模拟器报错解决方法
- 基于jni调用时,jvm报错问题的深入分析
- innerHTML在IE中报错解决方案
- mysql报错:MySQL server version for the right syntax to use near type=InnoDB的解决方法
- mysql登录报错提示:ERROR 1045 (28000)的解决方法
- thinkphp项目部署到Linux服务器上报错“模板不存在”如何解决
- Mysql 报Row size too large 65535 的原因及解决方法
- PHP执行Curl时报错提示CURL ERROR: Recv failure: Connection reset by peer的解决方法
- Android程序报错程序包org.apache.http不存在问题的解决方法
- 解决eclipse启动时报错Failed to create the Java Virtural Machine.问题的方法
- Android开发中Eclipse报错及对应处理方法总结
- Yii使用DeleteAll连表删除出现报错问题的解决方法
- php5.4传引用时报错问题分析