/docker-sonarqube

SonarQube(Docker) + MySQL(Docker) for production

Primary LanguageShellGNU Lesser General Public License v3.0LGPL-3.0

SonarQube(Docker) Operational Manual

Introduction

This is a setup guide for SonarQube in production using MySQL as DB.

Prerequisite

Operating System: Ubuntu

Software/Tools:

  • Docker (official installation guide)
    • install by running command: wget -qO- https://get.docker.com/ | sh
  • MySQL client
    • install by running command: sudo apt-get install mysql-client

Initial Setup

  1. On hosting server

    1. Start MySQL container:
    docker run --name sonardb -p 3306:3306 -v /opt/sonarqube/data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=sonar -e MYSQL_DATABASE=sonar -e MYSQL_USER=sonar -e MYSQL_PASSWORD=sonar -d mysql:5.6
    1. Check status:
    docker logs -f sonardb

    Wait until you see "MySQL init process done. Ready for start up." in the log.

    1. Start SonarQube container linked to MySQL:
    docker run --name sonarqube --link sonardb:mysql -p 9000:9000 -e SONARQUBE_JDBC_USERNAME=sonar -e SONARQUBE_JDBC_PASSWORD=sonar -e SONARQUBE_JDBC_URL="jdbc:mysql://mysql:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance" -v /opt/sonarqube/extensions/plugins:/opt/sonarqube/extensions/plugins -d sonarqube:5.1.2
    1. Check status:
    docker logs -f sonarqube

    Wait until you see "Process[web] is up" in the log.

  2. Go to http://hostname:9000/ to access SonarQube dashboard (default Admin user name: admin, password: admin)

Host server restarted -OR- Need to restart SonarQube

  1. docker restart sonardb
  2. docker logs -f sonardb
    Wait unitl see "mysqld: ready for connections." in the log.
  3. docker restart sonarqube
  4. docker logs -f sonarqube
    Wait unitl see "app[o.s.p.m.Monitor] Process[web] is up" in the log.

Backup and Restore

Back Up DB Data

On host server, first run below command

mysqldump --host=localhost --port=3306 --protocol TCP -u sonar -p sonar --single-transaction --databases sonar > sonardb_backup-<date>.sql
(password: sonar)

Then, store the backup sql file to a secure place.

Back Up SonarQube Plugins

Back up folder/directory:

  • /opt/sonarqube/extensions/plugins

Restore

Restore DB Data

On host server, navigate to folder/directory where DB backup file is stored. Then, run below command

mysql --host=localhost --port=3306 --protocol TCP -u sonar -p sonar < backup_file.sql
(password: sonar)
Restore others

Put back backup folders/directories.

Jenkins Integration

Refer: http://docs.sonarqube.org/display/PLUG/Jenkins+Plugin

Install Plugin on Jenkins

Refer: https://wiki.jenkins-ci.org/display/JENKINS/Plugins#Plugins-Howtoinstallplugins

Config Sonar Jenkins plugin

Refer: http://docs.sonarqube.org/display/PLUG/Configuring+Jenkins+SonarQube+Plugin

Only need to config below parameters, the rest can leave as default

  • Server URL http://<hostname or ip>:9000
  • Database URL jdbc:mysql://<jenkins>:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance