首页 > 解决方案 > 在使用 docker 容器 Sonnar Scanner 时使用 Jenkins 管道中的 SonarQube 分析代码

问题描述

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

我试图创建这个管道:

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

标签: jenkinssonarqubejenkins-pipeline

解决方案


我会尝试删除参数之间的双反斜杠: sh 'sonar-scanner -Dsonar.projectKey=myProject -Dsonar.sources=./src'

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


推荐阅读