Start Free
SonarQube Community Build | Server installation and setup | SonarQube Community Build | Installing from the Docker image

Installing SonarQube Community Build from the Docker image

On this page

SonarQube Community Build docker images support running both on the amd64 architecture and on arm64-based Apple Silicon.

We recommend using Docker Engine version 20.10 and above.

First, check the requirements and perform the pre-installation steps. Then follow these steps for your first installation:

Create volumes to persist data

Creating the following volumes helps prevent the loss of information when updating to a new version or upgrading to a higher edition:

    • sonarqube_data: contains data files, such as Elasticsearch indexes
    • sonarqube_logs: contains SonarQube Community Build logs about access, web process, CE process, and Elasticsearch
    • sonarqube_extensions: will contain any plugins you install and the Oracle JDBC driver if necessary.

Create the volumes with the following commands: 

$> docker volume create --name sonarqube_data
$> docker volume create --name sonarqube_logs
$> docker volume create --name sonarqube_extensions

Add the JDBC driver (if using an Oracle database)

Drivers for supported databases (except Oracle) are already provided. If you're using an Oracle database, you need to add the JDBC driver to the sonar_extensions volume. To do this:

 a. Start the SonarQube Community Buildv container with the embedded H2 database:

$ docker run --rm \
    -p 9000:9000 \
    -v sonarqube_extensions:/opt/sonarqube/extensions \
    <image_name>

where <image_name> is:

  • for SonarQube Community Build: sonarqube
  • for SonarQube Community Build Editions: check the tags currently available on the DockerHub page

b. Exit once SonarQube has started properly.

c. Copy the Oracle JDBC driver into sonarqube_extensions/jdbc-driver/oracle.

Start the SonarQube Community Build container

Start the SonarQube Community Build container:

  • either from the command line (docker run) or 
  • from a configuration file (docker compose). 

For docker-based setups, environment variables supersede all parameters that were provided with properties. See Docker environment variables for more details.

There is more information about installing and updating SonarQube Community Build plugins inside your Docker volume found on the Install a plugin page.

Port binding

By default, the server running within the container will listen on port 9000. You can expose the container port 9000 to the host port 9000 with the -p 9000:9000 argument to docker run, like the command below:

docker run --name sonarqube-custom -p 9000:9000 sonarqube:10.6-community

You can then browse to http://localhost:9000 or http://host-ip:9000 in your web browser to access the SonarQube Community Build web interface.

Starting the container by using docker run

Run the image with your database properties defined using the -e environment variable flag:

$> docker run -d --name sonarqube \
    -p 9000:9000 \
    -e SONAR_JDBC_URL=... \
    -e SONAR_JDBC_USERNAME=... \
    -e SONAR_JDBC_PASSWORD=... \
    -v sonarqube_data:/opt/sonarqube/data \
    -v sonarqube_extensions:/opt/sonarqube/extensions \
    -v sonarqube_logs:/opt/sonarqube/logs \
    <image_name>

where <image_name> is:

  • for SonarQube Community Build: sonarqube
  • for the SonarQube Community Build Editions: check the tags currently available on the DockerHub page

Starting the container by using Docker compose

If you're using Docker Compose, use this yml file example as a reference when configuring your .yml file. In the image tag, use the tag value corresponding to the SonarQube Community Build version you want to use, e.g, to use the LTA version of the Developer Edition:

image:  sonarqube:lts-developer

Check the SonarQube Community Build image tags currently available on the DockerHub page

Next steps

Once your server is installed and running, you can access SonarQube Community Build UI in your web browser (the default system administrator credentials are admin/admin) and you're ready to begin analyzing source code.


Was this page helpful?

© 2008-2024 SonarSource SA. All rights reserved. SONAR, SONARSOURCE, SONARQUBE, and CLEAN AS YOU CODE are trademarks of SonarSource SA.

Creative Commons License