1

スムーズなSonarQubeサーバーv5.3がありました。すべてが順調に進んでいました。そして今日、不要なプロジェクトをいくつか削除することにしました。削除はうまくいきました、または少なくとも私はそう思っていました。それらはGUIから消えました。

DB もチェックインしましたが、このコマンドでは表示されません。

select * from projects where kee like '%sonar%'

問題は、これらのプロジェクトを削除した後、ソナー分析を再度実行しようとすると、プロジェクトはプロビジョニングされているだけですが、分析は実行されません。に行くとDBエラーが発生します

管理 > バックグラウンド タスク > ログ

エラーは次のとおりです。

2016.05.10 15:59:43 INFO  [o.s.s.c.s.ComputationStepExecutor] Execute component visitors | time=6135ms
2016.05.10 15:59:43 INFO  [o.s.s.c.s.ComputationStepExecutor] Compute measure variations | time=1ms
2016.05.10 15:59:43 INFO  [o.s.s.c.s.ComputationStepExecutor] Computes Quality Gate measures | time=1ms
2016.05.10 15:59:43 INFO  [o.s.s.c.s.ComputationStepExecutor] Compute Quality profile measures | time=18ms
2016.05.10 15:59:43 INFO  [o.s.s.c.s.ComputationStepExecutor] Generate Quality profile events | time=4ms
2016.05.10 15:59:43 INFO  [o.s.s.c.s.ComputationStepExecutor] Generate Quality gate events | time=3ms
2016.05.10 15:59:44 ERROR [o.s.s.c.t.CeWorkerCallableImpl] Failed to execute task AVSa9zwoeZCFdUKsTOSM
org.sonar.server.computation.component.VisitException: Visit failed for Component {key=com.som.lan:lan-biz:src/main/java/sb1/biz/financing/demo,type=DIRECTORY}  located com.som.lan:lan-biz(type=MODULE)->com.som:lan(type=MODULE)->com.som:modules(type=MODULE)->bm-master_feature_dig-9129-javascript-in-sonar(type=PROJECT)
    at org.sonar.server.computation.component.VisitException.rethrowOrWrap(VisitException.java:44) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visit(PathAwareCrawler.java:52) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitChildren(PathAwareCrawler.java:87) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitImpl(PathAwareCrawler.java:70) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visit(PathAwareCrawler.java:50) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitChildren(PathAwareCrawler.java:87) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitImpl(PathAwareCrawler.java:70) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visit(PathAwareCrawler.java:50) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitChildren(PathAwareCrawler.java:87) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitImpl(PathAwareCrawler.java:70) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visit(PathAwareCrawler.java:50) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitChildren(PathAwareCrawler.java:87) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visitImpl(PathAwareCrawler.java:70) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.component.PathAwareCrawler.visit(PathAwareCrawler.java:50) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.step.PersistComponentsStep.execute(PersistComponentsStep.java:77) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.step.ComputationStepExecutor.execute(ComputationStepExecutor.java:39) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.taskprocessor.report.ReportTaskProcessor.process(ReportTaskProcessor.java:72) ~[sonar-server-5.3.jar:na]
    at org.sonar.server.computation.taskprocessor.CeWorkerCallableImpl.executeTask(CeWorkerCallableImpl.java:81) [sonar-server-5.3.jar:na]
    at org.sonar.server.computation.taskprocessor.CeWorkerCallableImpl.call(CeWorkerCallableImpl.java:56) [sonar-server-5.3.jar:na]
    at org.sonar.server.computation.taskprocessor.CeWorkerCallableImpl.call(CeWorkerCallableImpl.java:35) [sonar-server-5.3.jar:na]
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) [na:1.8.0_72]
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) [na:1.8.0_72]
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) [na:1.8.0_72]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) [na:1.8.0_72]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) [na:1.8.0_72]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) [na:1.8.0_72]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) [na:1.8.0_72]
    at java.lang.Thread.run(Thread.java:745) [na:1.8.0_72]
Caused by: org.apache.ibatis.exceptions.PersistenceException:

データベースの更新中にエラーが発生しました。原因: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: 一意の制約(SONAR.PROJECTS_KEE)に違反しています

エラーには org.sonar.db.component.ComponentMapper.insert-Inline が関係している可能性があります

パラメータの設定中にエラーが発生しました

原因: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: 一意の制約(SONAR.PROJECTS_KEE)に違反しています

at org.apache.ibatis.exceptions.ExceptionFactory.wrapException(ExceptionFactory.java:26) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:154) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.session.defaults.DefaultSqlSession.insert(DefaultSqlSession.java:141) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.binding.MapperMethod.execute(MapperMethod.java:51) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.binding.MapperProxy.invoke(MapperProxy.java:52) ~[mybatis-3.2.7.jar:3.2.7]
at com.sun.proxy.$Proxy64.insert(Unknown Source) ~[na:na]
at org.sonar.db.component.ComponentDao.insert(ComponentDao.java:282) ~[sonar-db-5.3.jar:na]
at org.sonar.server.computation.step.PersistComponentsStep$PersistComponentStepsVisitor.persistComponent(PersistComponentsStep.java:172) ~[sonar-server-5.3.jar:na]
at org.sonar.server.computation.step.PersistComponentsStep$PersistComponentStepsVisitor.persistAndPopulateCache(PersistComponentsStep.java:164) ~[sonar-server-5.3.jar:na]
at org.sonar.server.computation.step.PersistComponentsStep$PersistComponentStepsVisitor.visitDirectory(PersistComponentsStep.java:136) ~[sonar-server-5.3.jar:na]
at org.sonar.server.computation.component.PathAwareCrawler.visitNode(PathAwareCrawler.java:102) ~[sonar-server-5.3.jar:na]
at org.sonar.server.computation.component.PathAwareCrawler.visitImpl(PathAwareCrawler.java:67) ~[sonar-server-5.3.jar:na]
at org.sonar.server.computation.component.PathAwareCrawler.visit(PathAwareCrawler.java:50) ~[sonar-server-5.3.jar:na]
... 26 common frames omitted

原因: java.sql.SQLIntegrityConstraintViolationException: ORA-00001: 一意の制約 (SONAR.PROJECTS_KEE) 違反

at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:447) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4CTTIoer.processError(T4CTTIoer.java:396) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4C8Oall.processError(T4C8Oall.java:951) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4CTTIfun.receive(T4CTTIfun.java:513) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4CTTIfun.doRPC(T4CTTIfun.java:227) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4C8Oall.doOALL(T4C8Oall.java:531) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4CPreparedStatement.doOall8(T4CPreparedStatement.java:208) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.T4CPreparedStatement.executeForRows(T4CPreparedStatement.java:1046) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.OracleStatement.doExecuteWithTimeout(OracleStatement.java:1336) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.OraclePreparedStatement.executeInternal(OraclePreparedStatement.java:3613) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.OraclePreparedStatement.execute(OraclePreparedStatement.java:3714) ~[ojdbc6.jar:11.2.0.4.0]
at oracle.jdbc.driver.OraclePreparedStatementWrapper.execute(OraclePreparedStatementWrapper.java:1378) ~[ojdbc6.jar:11.2.0.4.0]
at org.apache.commons.dbcp.DelegatingPreparedStatement.execute(DelegatingPreparedStatement.java:172) ~[commons-dbcp-1.4.jar:1.4]
at org.apache.commons.dbcp.DelegatingPreparedStatement.execute(DelegatingPreparedStatement.java:172) ~[commons-dbcp-1.4.jar:1.4]
at org.apache.ibatis.executor.statement.PreparedStatementHandler.update(PreparedStatementHandler.java:44) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.executor.statement.RoutingStatementHandler.update(RoutingStatementHandler.java:69) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.executor.ReuseExecutor.doUpdate(ReuseExecutor.java:50) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.executor.BaseExecutor.update(BaseExecutor.java:105) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.executor.CachingExecutor.update(CachingExecutor.java:71) ~[mybatis-3.2.7.jar:3.2.7]
at org.apache.ibatis.session.defaults.DefaultSqlSession.update(DefaultSqlSession.java:152) ~[mybatis-3.2.7.jar:3.2.7]
... 37 common frames omitted

2016.05.10 15:59:44 ERROR [ossctCeWorkerCallableImpl] 実行されたタスク | プロジェクト=bm-master_feature_dig-9129-javascript-in-sonar | id=AVSa9zwoeZCFdUKsTOSM | 時間=8689ms

このエラーは、プロジェクト名に関係なく表示されます。プロジェクト名自体ではなく、モジュールが一意の制約を引き起こしているようです。

私が試してみました:

  • GUI を使用してプロジェクトを削除する
  • ソナーの停止と再起動

テーブルを見て何かを理解できるかどうかを確認する以外に、DBで手動で何もしていません。

どうすればこれを取り除くことができますか?

ありがとう :)

編集:

次のようにmavenでソナーを実行しています:

mvn -e sonar:sonar \
-DskipTests \
-DXmx2g \
-DXX:MaxPermSize=1g \
-Dsonar.host.url=http://sonar.myserver.com \
-Dsonar.projectKey=${sonarProjectName} \
-Dsonar.projectName=${sonarProjectName} \
-Dsonar.projectVersion=${branch} \
-Dsonar.forceAnalysis=true \
-Dsonar.sourceEncoding=UTF-8 \
-Dmaven.test.failure.ignore=true \
-Dsonar.sources=. \
-Dsonar.exclusions=**/target/**/*,**/src/lib/**/*,**/node_modules/**/* \
-Dsonar.test.exclusions=**/src/test/java/** \
-Dsonar.junit.reportsPath=**/target/surefire-reports \
-Dsonar.jacoco.reportPath=${WORKSPACE}/target/jacoco.exec \
-Dsonar.jacoco.itReportPath=${WORKSPACE}/target/jacoco-it.exec \
-Dsonar.java.binaries=**/target/classes \
-Dsonar.java.coveragePlugin=jacoco \
-Dsonar.verbose=true

ここでの IT セットアップの性質上、Jenkins SonarQube Runner プラグインを使用できません。別のプロジェクトで使用していますが、問題なく動作します。

4

1 に答える 1

0

この問題は解決しましたが、そもそもなぜ問題が発生したのかわかりません。

解決策は src demo ディレクトリを除外することだったので、除外を次のように変更しました。

    -Dsonar.exclusions=**/target/**/*,**/src/lib/**/*,**/node_modules/**/*,**/src/main/java/**/demo/**/* \

エラーが表示された理由はわかりません。後でソナー ホストの管理 GUI を調べていたところ、[管理] > [一般設定] > [分析範囲] > [既に持っているファイル] の下に表示されました。

**/demo/*.java

ソース ファイルの除外として。

それが Unique 制約エラーの原因だったのだろうか? とにかく、これよりも良い応答が得られることを願っているので、エラーが発生した理由はわかっています。

于 2016-05-11T09:09:22.050 に答える