2017-11-13 21 views
1

現在約10,000件の大きなプロジェクト(〜35,000件のJavaファイル)があります。約3週間前、私たちの夜間スキャンはバージョンsonarqube 6.5で失敗し始めました。私は6.6にアップグレードし、同じ問題を発見した。まず、ヒープスペースが原因で失敗していました。私はそれをより多くのメモリを与えるために、このマシンをアップグレードしていると分析が終了するように思われる。今度は、バックグラウンドタスク中に毎晩スキャンが失敗し、「開いているファイルが多すぎます」という理由で分析をポストします。ソナーユーザーのためのオープンファイルの制限を引き上げましたが、それは効果がないようです。他にも小さなプロジェクトがあり、簡単に完成します。これは絶えず失敗するこの非常に大きなプロジェクトです。誰もこれを見たことがありますか?Sonarqubeバックグラウンドタスク(オープンファイルが多すぎます)

今朝私はそれを修正するかどうかを確認するためにsonarqube 6.7をインストールしました。私は現在分析を行っていますが、終了して失敗するには約3時間かかります。

ソナーユーザーに許可されているオープンファイルの数を増やしました。ここで

-sh-4.1$ whoami 
sonar 
-sh-4.1$ ulimit -Hs 
unlimited 
-sh-4.1$ ulimit -Hn 
1048576 

、我々はあまりにも多くの開いているファイルで、このエラー固定SonarQube 6.7へ

org.sonar.server.computation.task.projectanalysis.component.VisitException: Visit of Component {key=applications:sonar:src/main/java/com/MyFileName.java,type=FILE} failed 
    at org.sonar.server.computation.task.projectanalysis.component.VisitException.rethrowOrWrap(VisitException.java:44) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visit(VisitorsCrawler.java:74) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visitChildren(VisitorsCrawler.java:110) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visitImpl(VisitorsCrawler.java:97) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visit(VisitorsCrawler.java:72) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visitChildren(VisitorsCrawler.java:110) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visitImpl(VisitorsCrawler.java:97) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visit(VisitorsCrawler.java:72) 
    at org.sonar.server.computation.task.projectanalysis.step.ExecuteVisitorsStep.execute(ExecuteVisitorsStep.java:51) 
    at org.sonar.server.computation.task.step.ComputationStepExecutor.executeSteps(ComputationStepExecutor.java:64) 
    at org.sonar.server.computation.task.step.ComputationStepExecutor.execute(ComputationStepExecutor.java:52) 
    at org.sonar.server.computation.task.projectanalysis.taskprocessor.ReportTaskProcessor.process(ReportTaskProcessor.java:75) 
    at org.sonar.ce.taskprocessor.CeWorkerImpl.executeTask(CeWorkerImpl.java:92) 
    at org.sonar.ce.taskprocessor.CeWorkerImpl.call(CeWorkerImpl.java:59) 
    at org.sonar.ce.taskprocessor.CeWorkerImpl.call(CeWorkerImpl.java:35) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) 
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) 
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) 
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) 
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
    at java.lang.Thread.run(Thread.java:745) 
Caused by: java.lang.IllegalStateException: Fail to process issues of component 'applications:sonar:src/main/java/com/MyFileName.java' 
    at org.sonar.server.computation.task.projectanalysis.issue.IntegrateIssuesVisitor.processIssues(IntegrateIssuesVisitor.java:83) 
    at org.sonar.server.computation.task.projectanalysis.issue.IntegrateIssuesVisitor.visitAny(IntegrateIssuesVisitor.java:63) 
    at org.sonar.server.computation.task.projectanalysis.component.TypeAwareVisitorWrapper.visitAny(TypeAwareVisitorWrapper.java:82) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visitNode(VisitorsCrawler.java:117) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visitImpl(VisitorsCrawler.java:100) 
    at org.sonar.server.computation.task.projectanalysis.component.VisitorsCrawler.visit(VisitorsCrawler.java:72) 
    ... 21 more 
Caused by: java.lang.IllegalStateException: Fail to traverse file: /opt/sonarqube-6.5/temp/ce/6622607282221286408/1421069522563365386/source-11991.txt 
    at org.sonar.server.computation.task.projectanalysis.batch.BatchReportReaderImpl.readFileSource(BatchReportReaderImpl.java:153) 
    at org.sonar.server.computation.task.projectanalysis.source.SourceLinesRepositoryImpl.readLines(SourceLinesRepositoryImpl.java:45) 
    at org.sonar.server.computation.task.projectanalysis.issue.TrackerRawInputFactory$RawLazyInput.loadLineHashSequence(TrackerRawInputFactory.java:80) 
    at org.sonar.core.issue.tracking.LazyInput.getLineHashSequence(LazyInput.java:34) 
    at org.sonar.server.computation.task.projectanalysis.issue.TrackerRawInputFactory$RawLazyInput.loadIssues(TrackerRawInputFactory.java:105) 
    at org.sonar.core.issue.tracking.LazyInput.getIssues(LazyInput.java:50) 
    at org.sonar.core.issue.tracking.Tracking.<init>(Tracking.java:46) 
    at org.sonar.core.issue.tracking.Tracker.track(Tracker.java:37) 
    at org.sonar.server.computation.task.projectanalysis.issue.TrackerExecution.track(TrackerExecution.java:41) 
    at org.sonar.server.computation.task.projectanalysis.issue.IntegrateIssuesVisitor.processIssues(IntegrateIssuesVisitor.java:76) 
    ... 26 more 
Caused by: java.io.FileNotFoundException: /opt/sonarqube-6.5/temp/ce/6622607282221286408/1421069522563365386/source-11991.txt (Too many open files) 
    at java.io.FileInputStream.open0(Native Method) 
    at java.io.FileInputStream.open(FileInputStream.java:195) 
    at java.io.FileInputStream.<init>(FileInputStream.java:138) 
    at org.apache.commons.io.FileUtils.openInputStream(FileUtils.java:301) 
    at org.sonar.server.computation.task.projectanalysis.batch.BatchReportReaderImpl.readFileSource(BatchReportReaderImpl.java:151) 
    ... 35 more 

答えて

1

のアップグレードを見ているとエラーになります。

関連する問題