使用 docker 容器 Sonar Scanner 时使用 Jenkins 管道中的 SonarQube 分析代码

问题描述 投票:0回答:1

我想对 git 存储库代码执行 SonarQube 分析,并且我想使用 Docker 容器中的 SonarScanner,而不是从 Jenkins 配置中使用。

我尝试创建这个管道:

pipeline {
    agent { docker { image 'emeraldsquad/sonar-scanner:latest' } }
    stages {
        stage('build && SonarQube analysis') {
            steps {
                withSonarQubeEnv('sonar.tools.devops.****') {
                    sh 'sonar-scanner \\ -Dsonar.projectKey=myProject \\ -Dsonar.sources=./src \\'
                }
            }
        }
        stage("Quality Gate") {
            steps {
                timeout(time: 1, unit: 'HOURS') {
                    // Parameter indicates whether to set pipeline to UNSTABLE if Quality Gate fails
                    // true = set pipeline to UNSTABLE, false = don't
                    // Requires SonarScanner for Jenkins 2.7+
                    waitForQualityGate abortPipeline: true
                }
            }
        }
    }
}

构建在阶段构建和 SonarQube 分析中失败,构建输出:

Injecting SonarQube environment variables using the configuration: sonar.tools.devops.*****
[Pipeline] {
[Pipeline] sh
+ sonar-scanner ' -Dsonar.projectKey=myProject' ' -Dsonar.sources=./src' '\'
ERROR: Unrecognized option:  -Dsonar.sources=./src
INFO: 
INFO: usage: sonar-scanner [options]
INFO: 
INFO: Options:
INFO:  -D,--define <arg>     Define property
INFO:  -h,--help             Display help information
INFO:  -v,--version          Display version information
INFO:  -X,--debug            Produce execution debug output
jenkins sonarqube jenkins-pipeline
1个回答
1
投票

我会尝试删除参数之间的双反斜杠:

sh 'sonar-scanner -Dsonar.projectKey=myProject -Dsonar.sources=./src'

反斜杠转义空格,不会被 shell 截断,并添加到参数名称中。

© www.soinside.com 2019 - 2024. All rights reserved.