Operating the server
Running SonarQube as a service on Windows
Install or uninstall SonarQube as a service
Start or stop the service
By default, the service will use the Java executable available on the Windows PATH. This setting can be changed by setting the environmental variable SONAR_JAVA_PATH
. See more in Adjusting the Java installation.
> %SONARQUBE_HOME%\bin\windows-x86-64\SonarService.bat stop
does a graceful shutdown where no new analysis report processing can start, but the tasks in progress are allowed to finish. The time a stop will take depends on the processing time of the tasks in progress. You'll need to kill all SonarQube processes manually to force a stop.
Service status
Check if the SonarQube service is running:
Running SonarQube manually on Linux
Start or stop the instance
Stop does a graceful shutdown where no new analysis report processing can start, but the tasks in progress are allowed to finish. The time a stop will take depends on the processing time of the tasks in progress. Use force stop for a hard stop.
Running SonarQube as a service on Linux with SystemD
On a Unix system using SystemD, you can install SonarQube as a service. You cannot run SonarQube as root in Unix systems. Ideally, you will created a new account dedicated to the purpose of running SonarQube. Let's suppose:
- The user used to start the service is
sonarqube
- The group used to start the service is
sonarqube
- The Java Virtual Machine is installed in
/opt/java/
- SonarQube has been unzipped into
/opt/sonarqube/
Then create the file /etc/systemd/system/sonarqube.service
based on the following:
- Because the sonar-application jar name ends with the version of SonarQube, you will need to adjust the
ExecStart
command accordingly on install and at each upgrade. - All SonarQube directories should be owned by the
sonarqube
user.
Once your sonarqube.service
file is created and properly configured, run:
Running SonarQube as a service on Linux with initd
The following has been tested on Ubuntu 8.10 and CentOS 6.2.
Create the file /etc/init.d/sonar
with this content:
Register SonarQube at boot time (RedHat, CentOS, 64 bit):
Once registration is done, run:
Securing the server behind a proxy
This section helps you configure the SonarQube Server if you want to run it behind a proxy. This can be done for security concerns or to consolidate multiple disparate applications. To run the SonarQube server over HTTPS, see the HTTPS Configuration section below.
For security reasons, we recommend only giving external access to the main port.
Using an Apache Proxy
We assume that you've already installed Apache 2 with module mod_proxy, that SonarQube is running and available on http://private_sonar_host:sonar_port/
, and that you want to configure a Virtual Host for www.public_sonar.com
.
At this point, edit the HTTPd configuration file for the www.public_sonar.com
virtual host. Include the following to expose SonarQube via mod_proxy
at http://www.public_sonar.com/
Apache configuration is going to vary based on your own application's requirements and the way you intend to expose SonarQube to the outside world. If you need more details about Apache HTTPd and mod_proxy, please see http://httpd.apache.org.
Using Nginx
We assume that you've already installed Nginx, that you are using a Virtual Host for www.somecompany.com
and that SonarQube is running and available on http://sonarhost:sonarport/
.
At this point, edit the Nginx configuration file. Include the following to expose SonarQube at http://www.somecompany.com/
:
Nginx configuration will vary based on your own application's requirements and the way you intend to expose SonarQube to the outside world. If you need more details about Nginx, please see https://www.nginx.com/resources/admin-guide/reverse-proxy/.
Note that you may need to increase the max URL length since SonarQube requests can have URLs longer than 2048.
Using IIS
See: http://blog.jessehouwing.nl/2016/02/configure-ssl-for-sonarqube-on-windows.html
Note that the setup described in this blog post is not appropriate for SAML through IIS.
HTTPS configuration
Forward SonarQube custom headers
SonarQube adds custom HTTP headers. The reverse proxy should be configured to forward the following headers:
SonarQube-Authentication-Token-Expiration
This header is added to a web service response when using tokens to authenticate. Forwarding this header is not required for the SonarQube features to work properly.
Secure your network
To further lock down the communication in between the reverse proxy and SonarQube, you can define the following network rules:
Protocol | Source | Destination | Port | default |
TCP | Reverse Proxy | SonarQube | sonar.web.port | 9000 |
TCP | SonarQube | SonarQube | sonar.search.port | 9001 |
TCP | SonarQube | SonarQube | sonar.es.port | random |
You can further segment your network configuration if you specify a frontend network and keep Elasticsearch restricted to the loopback NiC.
Network | Parameter | Description | default |
Frontend | sonar.web.host | Frontend HTTP Network | 0.0.0.0 |
Elasticsearch | sonar.search.host | Elasticsearch Network | 127.0.0.1 |
Was this page helpful?