This version of the SonarQube documentation is no longer maintained. It relates to a version of SonarQube that is not active.

SonarScanner

The SonarScanner is the scanner to use when there is no specific scanner for your build system.

SonarScanner — 7.3 | Issue Tracker

7.3 2025-10-06 Support z/OS as an Operating System to execute Scanners Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


7.2 2025-07-21 Restore ability to run the scanner with Java 11, update dependencies Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


7.1 2025-03-21 Support for SonarQube Cloud regions Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


7.0.2 2025-02-14 Bug fix to support SONAR_TOKEN on old SonarQube versions Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


7.0.1 2025-02-03 Support empty truststore password Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


7.0 2025-01-20 Non-latin character support in properties files, ISO-8859-1 support dropped Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


6.2.1 2024-10-01 FIPS support and improved SSL configuration Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


6.2 2024-09-17 Support PKCS12 truststore generated with OpenSSL Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


6.1 2024-06-27 macOS and Linux AArch64 distributions Download scanner for: Linux x64 Linux AArch64 Windows x64 macOS x64 macOS AArch64 Docker Any (Requires a pre-installed JVM) Release notes


6.0 2024-06-04 New bootstrapping mechanism and JRE provisioning with SonarQube 10.6+ and SonarCloud Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


5.0.2 2025-06-02 Security fix Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


5.0.1 2023-08-04 Bug fix to the JRE binaries for Linux Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


5.0 2023-07-31 Update embedded JRE to Java 17 Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.8.1 2023-08-14 Security fix Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.8 2022-02-06 Update embedded JRE 11 to the latest, bug fixes Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.7 2022-02-02 Ease import of custom certificates with the Docker image, update embedded JRE 11 Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.6.2 2021-05-07 Update dependencies, bug fix Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.6.1 2021-04-30 Update dependencies Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.6 2021-01-13 Support for Bitbucket Pipelines with SonarQube 8.7+ Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.5 2020-10-05 Fix a bug preventing the analysis in some environments Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.4 2020-07-03 New supported Docker image, bug fix Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.3 2019-03-09 Use SonarScanner name and better handle SonarCloud case in logs Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.2 2019-10-01 Support SONAR_HOST_URL environment variable to configure the server URL Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes


4.1 2019-09-09 Improve the use of a custom project configuration file Download scanner for: Linux x64 Windows x64 macOS x64 Docker Any (Requires a pre-installed JVM) Release notes

The SonarScanner is the scanner to use when there is no specific scanner for your build system. The SonarScanner does not support ARM architecture.

Configuring your project

Create a configuration file in your project’s root directory called sonar-project.properties.

# must be unique in a given SonarQube instance
sonar.projectKey=my:project

# --- optional properties ---

# defaults to project key
#sonar.projectName=My project
# defaults to 'not provided'
#sonar.projectVersion=1.0
 
# Path is relative to the sonar-project.properties file. Defaults to .
#sonar.sources=.
 
# Encoding of the source code. Default is default system encoding
#sonar.sourceEncoding=UTF-8

Running SonarScanner from the zip file

To run SonarScanner from the zip file, follow these steps:

  1. Expand the downloaded file into the directory of your choice. We’ll refer to it as <INSTALL_DIRECTORY> in the next steps.

  2. Update the global settings to point to your SonarQube server by editing $install_directory/conf/sonar-scanner.properties:

    #----- Default SonarQube server #sonar.host.url=http://localhost:9000

  3. Add the <INSTALL_DIRECTORY>/bin directory to your path.

  4. Verify your installation by opening a new shell and executing the command sonar-scanner -h (sonar-scanner.bat -h on Windows). You should get an output like this: usage: sonar-scanner [options]

    Options: -D,--define <arg> Define property -h,--help Display help information -v,--version Display version information -X,--debug Produce execution debug output

    If you need more debug information, you can add one of the following to your command line: -X, --verbose, or -Dsonar.verbose=true.

  5. Run the following command from the project base directory to launch analysis and pass your Generating and using tokens: sonar-scanner -Dsonar.login=myAuthenticationToken

Running SonarScanner from the Docker image

To scan using the SonarScanner Docker image, use the following command:

docker run \
    --rm \
    -e SONAR_HOST_URL="http://${SONARQUBE_URL}" \
    -e SONAR_SCANNER_OPTS="-Dsonar.projectKey=${YOUR_PROJECT_KEY}" \
    -e SONAR_LOGIN="myAuthenticationToken" \
    -v "${YOUR_REPO}:/usr/src" \
    sonarsource/sonar-scanner-cli

Scanning C, C++, or ObjectiveC projects

Scanning projects that contain C, C++, or Objective-C code requires some additional analysis steps. You can find full details on the C/C++/Objective-C language page.

Sample projects

To help you get started, simple project samples are available for most languages on GitHub. They can be browsed or downloaded. You’ll find them filed under sonarqube-scanner/src.

Alternatives to sonar-project.properties

If a sonar-project.properties file cannot be created in the root directory of the project, there are several alternatives:

  • The properties can be specified directly through the command line. Example: sonar-scanner -Dsonar.projectKey=myproject -Dsonar.sources=src1

  • The property project.settings can be used to specify the path to the project configuration file (this option is incompatible with the sonar.projectBaseDir property). Example: sonar-scanner -Dproject.settings=../myproject.properties

  • The root folder of the project to analyze can be set through the sonar.projectBaseDir property since SonarScanner 2.4. This folder must contain a sonar-project.properties file if sonar.projectKey is not specified on the command line. Additional analysis parameters can be defined in this project configuration file or through command-line parameters.

Alternate analysis directory

If the files to be analyzed are not in the directory where the analysis starts from, use the sonar.projectBaseDir property to move analysis to a different directory. E.G. analysis begins from jenkins/jobs/myjob/workspace but the files to be analyzed are in ftpdrop/cobol/project1. This is configured in sonar-project.properties as follows:

sonar.projectBaseDir=/home/ftpdrop/cobol/project1
sonar.sources=src
sonar.cobol.copy.directories=/copy

You can configure more parameters. See Analysis parameters for details.

Advanced Docker configuration

The following sections offer advanced configuration options when running the SonarScanner with Docker. Click the headings to expand the instructions.

Running as a non-root user

You can run the Docker image as a non-root user using the --user option. For example, to run as the current user:

docker run \
    --rm \
    --user="$(id -u):$(id -g)" \
    -e SONAR_HOST_URL="http://${SONARQUBE_URL}"  \
    -v "${YOUR_REPO}:/usr/src" \
    sonarsource/sonar-scanner-cli
Caching scanner files

To prevent SonarScanner from re-downloading language analyzers each time you run a scan, you can mount a directory where the scanner stores the downloads so that the downloads are reused between scanner runs. On some CI systems, you also need to add this directory to your CI cache configuration.

The following command will store and use cache between runs:

docker run \
    --rm \
    -v ${YOUR_CACHE_DIR}:/opt/sonar-scanner/.sonar/cache \
    -v ${YOUR_REPO}:/usr/src \
    -e SONAR_HOST_URL="http://${SONARQUBE_URL}" \
    sonarsource/sonar-scanner-cli

You can also change the location of where the scanner puts the downloads with the SONAR_USER_HOME environment variable.

Using self-signed certificates

If you need to configure a self-signed certificate for the scanner to communicate with your SonarQube instance, you can use a volume under /tmp/cacerts to add it to the containers java trust store:

docker pull sonarsource/sonar-scanner-cli
docker run \
    --rm \
    -v ${YOUR_CERTS_DIR}/cacerts:/tmp/cacerts \
    -v ${YOUR_CACHE_DIR}:/opt/sonar-scanner/.sonar/cache \
    -v ${YOUR_REPO}:/usr/src \
    -e SONAR_HOST_URL="http://${SONARQUBE_URL}" \
    sonarsource/sonar-scanner-cli

Alternatively, you can create your own container that includes the modified cacerts file. Create a Dockerfile with the following contents:

FROM sonarsource/sonar-scanner-cli
COPY cacerts /usr/lib/jvm/default-jvm/jre/lib/security/cacerts

Then, assuming both the cacerts and Dockerfile are in the current directory, create the new image with a command such as:

docker build --tag our-custom/sonar-scanner-cli .

Troubleshooting

Java heap space error or java.lang.OutOfMemoryError

Increase the memory via the SONAR_SCANNER_OPTS environment variable when running the scanner from a zip file:

export SONAR_SCANNER_OPTS="-Xmx512m"

In Windows environments, avoid the double quotes, since they get misinterpreted, and combine the two parameters into a single one.

set SONAR_SCANNER_OPTS=-Xmx512m

"java" cannot be opened because the developer cannot be verified

The SonarScanner CLI is not yet Apple verified therefore, when using the macOS AArch64 version, you may get an OS security window displaying this message. A solution us to run:

sudo xattr -dr com.apple.quarantine /path/to/sonar-scanner-version-macosx-aarch64

Note that the SonarScanner does not yet officially support ARM architecture. Still, early adopters reported it is working fine. If you encounter other problems when running the scanner on ARM architecture, don’t hesitate to share your experience with us on the SonarQube or SonarCloud Community Forum but keep in mind that there is no support at this time.

Unsupported major.minor version

Install the last version of SonarScanner CLI (from version 6.0, no JRE installation is required). Otherwise, upgrade the version of Java being used for analysis or use one of the native package (that embed its own Java runtime).

Property missing: ‘sonar.cs.analyzer.projectOutPaths’. No protobuf files will be loaded for this project.

Scanner CLI is not able to analyze .NET projects. Please, use the SonarScanner for .NET. If you are running the SonarScanner for .NET, ensure that you are not hitting a known limitation.

Last updated

Was this helpful?