【问题标题】:Sonar in Jenkins 2 Pipeline - missing global configJenkins 2 Pipeline 中的声纳 - 缺少全局配置
【发布时间】:2017-03-17 01:29:45
【问题描述】:

我尝试在我的 Jenkins 管道项目中使用 maven 运行声纳测试。文档说,如果声纳是全局配置的,并且您使用withSonarQube 步骤,则注入具有全局配置的声纳属性的环境变量。到目前为止一切顺利。

http://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner+for+Jenkins#AnalyzingwithSonarQubeScannerforJenkins-AnalyzingwithSonarQubeScannerforMaven

我的管道配置如下:

def stash = '********'
def branch = 'dev'

stage('git') {
    node {
        git branch: branch, credentialsId: 'Buildserver-Private.key', url: stash

    }
}

stage('build') {
    node {
        //....
    }
}

stage('sonar') {
    node {
        withSonarQubeEnv('Sonar') {
           sh 'mvn org.sonarsource.scanner.maven:sonar-maven-plugin:3.2:sonar'
        } 
    }
}

构建失败,因为声纳插件尝试连接到默认的 h2 数据库而不是配置的数据库。如果我检查日志,则没有传递给 maven 的声纳属性。

Injecting SonarQube environment variables using the configuration: Sonar
[Pipeline] {
[Pipeline] tool
[Pipeline] sh
[***********] Running shell script
+ cd .
+ /var/lib/jenkins/tools/hudson.tasks.Maven_MavenInstallation/Maven_3_3_9/bin/mvn org.sonarsource.scanner.maven:sonar-maven-plugin:3.2:sonar
[INFO] Scanning for projects...

[...]

[INFO] --- sonar-maven-plugin:3.2:sonar (default-cli) @ *******.project.build ---
[INFO] User cache: /var/lib/jenkins/.sonar/cache
[INFO] SonarQube version: 4.5.6
[INFO] Default locale: "en_US", source code encoding: "UTF-8" (analysis is platform dependent)
12:23:17.971 INFO  - Load global referentials...
12:23:18.071 INFO  - Load global referentials done: 102 ms
12:23:18.102 INFO  - User cache: /var/lib/jenkins/.sonar/cache
12:23:18.109 INFO  - Install plugins
12:23:18.176 INFO  - Install JDBC driver
12:23:18.183 INFO  - Create JDBC datasource for jdbc:h2:tcp://localhost/sonar

为什么我的配置被忽略了?如果文档说的话是什么意思?

自 Jenkins 的 SonarQube 扫描仪 2.5 版以来,有一个 Jenkins 流水线的官方支持。我们提供了一个'withSonarQubeEnv' 允许选择要交互的 SonarQube 服务器的块 和。您在 Jenkins 全局中配置的连接详细信息 配置将自动传递给扫描仪。

好像不是……

有人知道我错过了什么吗?

【问题讨论】:

    标签: jenkins sonarqube jenkins-pipeline sonarqube-scan


    【解决方案1】:

    您使用的是旧版本的 SonarQube(4.5.6,之前的 LTS),需要将数据库连接参数(URL、登录名、密码)传递给扫描仪 - 这是一个安全问题。 withSonarQubeEnv 不会传播这些设置以修复此缺陷。

    自 SonarQube 5.2 起,不再需要这些参数。所以你必须使用更新的版本。我建议您升级到最新的 LTS 版本的 SonarQube (5.6)。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2016-05-11
      • 1970-01-01
      • 1970-01-01
      • 2015-07-09
      • 2017-11-25
      • 2013-03-10
      • 2012-08-20
      • 1970-01-01
      相关资源
      最近更新 更多