2016-07-11 101 views
1

我已成功地使用SonarQube插件爲Jenkins集成了SonarQube和Jenkins。 Sonar分析似乎很成功,但我在Sonar儀表板上看不到結果。這裏是堆棧跟蹤:SonarQube + Jenkins錯誤500

INFO: Sensor SCM Sensor 
INFO: SCM provider for this project is: git 
INFO: 6 files to be analyzed 
INFO: 6/6 files analyzed 
INFO: Sensor SCM Sensor (done) | time=343ms 
INFO: Sensor Zero Coverage Sensor 
INFO: Sensor Zero Coverage Sensor (done) | time=12ms 
INFO: Sensor Code Colorizer Sensor 
INFO: Sensor Code Colorizer Sensor (done) | time=1ms 
INFO: Sensor CPD Block Indexer 
INFO: JavaCpdBlockIndexer is used for java 
INFO: Sensor CPD Block Indexer (done) | time=20ms 
INFO: Calculating CPD for 6 files 
INFO: CPD calculation finished 
INFO: Analysis report generated in 65ms, dir size=39 KB 
INFO: Analysis reports compressed in 187ms, zip size=23 KB 
INFO:   ------------------------------------------------------------------------ 
INFO: EXECUTION FAILURE 
INFO: ------------------------------------------------------------------------ 
INFO: Total time: 4.083s 
INFO: Final Memory: 50M/385M 
INFO: ------------------------------------------------------------------------ 
ERROR: Error during SonarQube Scanner execution 
org.sonarqube.ws.client.HttpException: Error 500 on http://localhost:9000/api/ce/submit?projectKey=helloworld&projectName=Simple%20Java%20project%20analyzed%20with%20the%20SonarQube%20Runner 
at org.sonarqube.ws.client.BaseResponse.failIfNotSuccessful(BaseResponse.java:34) 
at org.sonar.batch.bootstrap.BatchWsClient.failIfUnauthorized(BatchWsClient.java:99) 
at org.sonar.batch.bootstrap.BatchWsClient.call(BatchWsClient.java:69) 
at org.sonar.batch.report.ReportPublisher.upload(ReportPublisher.java:172) 
at org.sonar.batch.report.ReportPublisher.execute(ReportPublisher.java:127) 
at org.sonar.batch.phases.PublishPhaseExecutor.publishReportJob(PublishPhaseExecutor.java:64) 
at org.sonar.batch.phases.PublishPhaseExecutor.executeOnRoot(PublishPhaseExecutor.java:51) 
at org.sonar.batch.phases.AbstractPhaseExecutor.execute(AbstractPhaseExecutor.java:86) 
at org.sonar.batch.scan.ModuleScanContainer.doAfterStart(ModuleScanContainer.java:192) 
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:241) 
at org.sonar.batch.scan.ProjectScanContainer.scanRecursively(ProjectScanContainer.java:236) 
at org.sonar.batch.scan.ProjectScanContainer.doAfterStart(ProjectScanContainer.java:226) 
at org.sonar.core.platform.ComponentContainer.startComponents(ComponentContainer.java:142) 
at org.sonar.core.platform.ComponentContainer.execute(ComponentContainer.java:127) 
at org.sonar.batch.task.ScanTask.execute(ScanTask.java:47) 
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:106) 
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(NativeMethodAccessorImpl.java:62) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
at java.lang.reflect.Method.invoke(Method.java:498) 
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) 

當我點擊鏈接它說

{"errors":[{"msg":"HTTP method POST is required"}]} 

我認爲解決的辦法是重新配置SQ所以它直接使用的目標URL,但我怎麼做呢?

+0

500表示服務器錯誤,請在* /logs/sonar.log*中查看服務器端發生的錯誤。 –

回答

1

我遇到了同樣的錯誤,Nicolas關於檢查sonar.log的意見幫助我診斷了這個問題。我在Windows上將此作爲Windows服務運行,並且該進程的用戶被設置爲默認的本地服務,因此它正在C:\ Windows \ System32下查找臨時文件夾。我將用戶帳戶更改爲實際的用戶帳戶,並解決了問題。

如果日誌中的錯誤無法找到臨時文件夾,請嘗試檢查Sonar正在運行的用戶帳戶。

1

在我的聲納它不把二進制數據到MySQL,所以我改變

max_allowed_pa​​cket個= 16M到

#max_allowed_pa​​cket = 256M

0

我有類似的問題,主要參數是'http'而不是'https'格式,導致重定向丟失POST信息

+0

你可以附上一些示例代碼嗎? – Cherniv