下載sonar
# 存放目錄
# mkdir -p /opt/soft/
# cd /opt/soft
# 下載sonar
# wget https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-7.6.zip
# unzip sonarqube-7.6.zip
# 將文件移動到/usr/local目錄
# mv sonarqube-7.6 /usr/local/sonarqube
創建運行sonar的CentOS賬戶sonar,並設置賬戶密碼:
# useradd sonar
# passwd sonar
# 賦權限
# chown -R sonar:sonar /usr/local/sonarqube
# chmod 760 /usr/local/sonarqube
# 修改命令執行權限
# vi /etc/sudoers
# 添加如下內容
# sonar ALL(ALL) ALL
配置數據庫
Apache Derby 是Sonar自帶並且默認安裝使用的數據庫,此外Sonar對如下數據庫提供支持:MySQL 5.x, Oracle 10g XE, Postgresql, MS SqlServer等,本文以mysql爲例介紹如何配置數據庫:
1)創建數據庫
在mysql中執行如下腳本創建數據庫及mysql用戶
CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'sonar' IDENTIFIED BY 'sonar';
GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY 'sonar';
GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY 'sonar';
FLUSH PRIVILEGES;
修改配置文件:
# vi /usr/local/sonarqube/conf/sonar.properties
sonar.jdbc.username=sonar
sonar.jdbc.password=sonar
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true
# ip
sonar.web.host=0.0.0.0
# 端口
sonar.web.port=9000
啓動
# /usr/local/sonarqube/bin/linux-x86-64/sonar.sh start
# 查看日誌
# tailf /usr/local/sonarqube/logs/sonar.log
# tailf /usr/local/sonarqube/logs/es.log
異常處理:
1、max file descriptors [4096] for elasticsearch process is too low, increase to at least [65536]
修改/etc/security/limits.conf文件,增加配置,用戶退出後重新登錄生效
* soft nofile 65536
* hard nofile 65536
2、max number of threads [3818] for user [es] is too low, increase to at least [4096]
問題同上,最大線程個數太低。修改配置文件/etc/security/limits.conf,增加配置
* soft nproc 4096
* hard nproc 4096
3、max virtual memory areas vm.max_map_count [65530] is too low, increase to at least [262144]
修改/etc/sysctl.conf文件,增加配置vm.max_map_count=262144
# vi /etc/sysctl.conf
# sysctl -p