一、sonarqube簡介
- SonarQube是管理代碼質量的一個開放平台,可以快速定位代碼中潛在的或者明顯的錯誤。支持Java, C#, C/C++, PL/SQL, Cobol, JavaScrip, Groovy 等二十幾種編程語言的代碼質量管理與檢測。
二、安裝postgresql數據庫
- 官網上已經聲明 sonarQube 7.9 版本以上不再支持 mysql 了,所以我們使用 postgresql
1、安裝鏡像
docker pull postgres:11
2、新建目錄
mkdir -p /home/apps/postgres/{postgresql,data}
3、創建並啟動
docker run -d --name postgres -p 5432:5432 \
-v /home/apps/postgres/postgresql:/var/lib/postgresql \
-v /home/apps/postgres/data:/var/lib/postgresql/data \
-v /etc/localtime:/etc/localtime:ro \
-e POSTGRES_USER=sonar \
-e POSTGRES_PASSWORD=sonar \
-e POSTGRES_DB=sonar \
-e TZ=Asia/Shanghai \
--restart always \
--privileged=true \
postgres:11
三、sonarqube安裝
1、安裝鏡像
docker pull sonarqube:8.9.2-community
2、新建目錄
mkdir -p /home/apps/sonarqube/{extensions,logs,data}
3、修改內核參數
- 不修改啟動會報錯:ERROR: Elasticsearch did not exit normally - check the logs at /opt/sonarqube/logs/sonarqube.log
vim /etc/sysctl.conf
# 增加以下配置
vm.max_map_count=262144
fs.file-max=65536
# 使配置生效
sysctl -p
4、創建並啟動
docker run -d --name sonarqube -p 6004:9000 \
--link postgres \
-v /home/apps/sonarqube/extensions:/opt/sonarqube/extensions \
-v /home/apps/sonarqube/logs:/opt/sonarqube/logs \
-v /home/apps/sonarqube/data:/opt/sonarqube/data \
-e SONARQUBE_JDBC_URL=jdbc:postgresql://postgres:5432/sonar \
-e SONARQUBE_JDBC_USERNAME=sonar \
-e SONARQUBE_JDBC_PASSWORD=sonar \
--restart always \
--privileged=true \
sonarqube:8.9.2-community
- --link 這個參數,這個是數據庫的容器名,后面的數據庫連接地址,同樣采用容器名進行連接
5、查看日志
docker logs sonarqube
6、開放6004端口
# 添加6004端口
firewall-cmd --zone=public --add-port=6004/tcp --permanent
# 重新載入
firewall-cmd --reload
7、頁面訪問
- http://ip:6004,默認賬號:admin,密碼:admin
8、sonar安裝中文插件
-
方式一:Administration->Marketplace->搜索chinese pack,進行相應版本的安裝,如下圖
-
方式二:下載地址:https://github.com/xuhuisheng/sonar-l10n-zh/tags ,找到自己版本對應的中文包,將 jar 包放入 /home/apps/sonarqube/extensions/plugins ,重啟 sonarqube
四、使用教程
- idea結合sqnarqube使用教程
- gitlab結合sonarqube使用教程
- 點擊進入查看