SonarQube代碼質量管理工具的安裝(Linux)

1、安裝配置sonar

一、Sonar介紹

Sonar是一個用於代碼質量管理的開源平臺,用於管理Java源代碼的質量。經過插件機制,Sonar 能夠集成不一樣的測試工具,代碼分析工具,以及持續集成工具,好比pmd-cpd、checkstyle、findbugs、Jenkins。經過不一樣的插件對這些結果進行再加工處理,經過量化的方式度量代碼質量的變化,從而能夠方便地對不一樣規模和種類的工程進行代碼質量管理。java

同時 Sonar 還對大量的持續集成工具提供了接口支持,能夠很方便地在持續集成中使用 Sonar。node

此外,Sonar 的插件還能夠對 Java 之外的其餘編程語言提供支持,對國際化以及報告文檔化也有良好的支持。mysql

注意:安裝sonar前, 請確保安裝好了jdk和MySQL,jdk版本爲7.0+,mysql爲5.6+,sonar爲5.6.6nginx

二、配置數據庫

Apache Derby 是Sonar自帶而且默認安裝使用的數據庫,此外Sonar對以下數據庫提供支持:MySQL 5.x, Oracle 10g XE, Postgresql, MS SqlServer等,本文以mysql爲例介紹如何配置數據庫:web

1) 配置mysql

結合 SonarQube, MySQL 數據庫最好使用 InnoDB 引擎, 可提升性能。 看你的 mysql 如今已提供什麼存儲引擎: 
mysql> show engines;
sql

看你的 mysql 當前默認的存儲引擎: 
mysql> show variables like ‘%storage_engine%’;
數據庫

修改 MySQL 存儲引擎爲 InnoDB, 在配置文件/etc/my.cnf 中加入 default-storage-engine=INNODB, 
重啓 mysql 服務器 # service mysqld restart, 再次登陸 MySQL 查看默認引擎設置是否生效 
mysql> show variables like ‘%storage_engine%’;
編程

innodb_buffer_pool_size 參數值設置得儘量大一點,這個參數主要做用是緩存 innodb 表的索引,數據,插入數據時的緩衝默認值: 128M, 專用 mysql 服務器設置的大小:操做系統內存的 70%-80%最佳。bootstrap

設置方法: my.cnf 文件[mysqld] 下面加入innodb_buffer_pool_size 參數 innodb_buffer_pool_size = 256M( 咱們這裏設置爲 256M, 由於咱們的不是專用的 MySQL 數據庫服務器,還有不少其餘的服務須要佔用系統內存) 
設置 MySQL 的查詢緩存 query_cache_size ,最少設置 15M, query_cache_type=1 
query_cache_size=32M 
重啓 mysql 服務器 service mysqld restart 
驗證緩存設置是否生效: 
mysql> show variables like ‘%query_cache%’;
後端

2)建立數據庫

在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’;

3)配置數據庫

編輯${SONAR_HOME}/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 # Optional properties sonar.jdbc.driverClassName: com.mysql.jdbc.Driver

三、安裝Sonar

解壓安裝: 
unzip sonarqube-4.5.4.zip 
mv sonarqube-4.5.4 sonarqube

編輯 sonar 配置: 
cd sonarqube/conf/ 
vi sonar.properties

sonar.jdbc.username=root 
sonar.jdbc.password=root 
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonarqube?useUnicode=true&characterE 
ncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance 
sonar.web.host=0.0.0.0 
sonar.web.context=/sonarqube 
sonar.web.port=9000

保存以上配置(注意,要看看默認的 9000 端口是否已被佔用) 
防火牆中打開 9000 端口: 
vi /etc/sysconfig/iptables 
-A INPUT -m state –state NEW -m tcp -p tcp –dport 9000 -j ACCEPT 
重啓防火牆, 使端口配置生效 
service iptables restart 
啓動 SonarQube Web Server 
/root/sonarqube/bin/Linux-x86-64/sonar.sh start( 初次啓動會自動建表和作相應的初始化)

瀏覽器中輸入: http://10.21.0.187:9000/sonarqube/

ps:當啓動sonar服務時,elasticsearch不能經過root啓動時,解決以下:

解決方法1:

  • 若是是用root帳號啓動,會報如下錯誤

    Exception in thread "main" java.lang.RuntimeException: don't run elasticsearch as root. at org.elasticsearch.bootstrap.Bootstrap.initializeNatives(Bootstrap.java:93) at org.elasticsearch.bootstrap.Bootstrap.setup(Bootstrap.java:144) at org.elasticsearch.bootstrap.Bootstrap.init(Bootstrap.java:285) at org.elasticsearch.bootstrap.Elasticsearch.main(Elasticsearch.java:35) Refer to the log for complete error details.
  • 這是出於系統安全考慮設置的條件。因爲ElasticSearch能夠接收用戶輸入的腳本而且執行,爲了系統安全考慮, 
    建議建立一個單獨的用戶用來運行ElasticSearch

  • 建立elsearch用戶組及elsearch用戶

    groupadd elsearch useradd elsearch -g elsearch -p elasticsearch
  • 更改elasticsearch文件夾及內部文件的所屬用戶及組爲elsearch:elsearch

    cd /opt chown -R elsearch:elsearch elasticsearch
  • 切換到elsearch用戶再啓動

    su elsearch cd elasticsearch/bin ./elasticsearch
  • 啓動後打印信息以下

    [2015-12-30 10:15:44,876][WARN ][bootstrap ] unable to install syscall filter: prctl(PR_GET_NO_NEW_PRIVS): Invalid argument [2015-12-30 10:15:45,175][INFO ][node ] [Grim Hunter] version[2.1.1], pid[26383], build[40e2c53/2015-12-15T13:05:55Z] [2015-12-30 10:15:45,176][INFO ][node ] [Grim Hunter] initializing ... [2015-12-30 10:15:45,243][INFO ][plugins ] [Grim Hunter] loaded [], sites [] [2015-12-30 10:15:45,272][INFO ][env ] [Grim Hunter] using [1] data paths, mounts [[/ (/dev/mapper/vg_yong-lv_root)]], net usable_space [33.3gb], net total_space [49gb], spins? [no], types [ext4] [2015-12-30 10:15:47,318][INFO ][node ] [Grim Hunter] initialized [2015-12-30 10:15:47,318][INFO ][node ] [Grim Hunter] starting ... [2015-12-30 10:15:47,388][INFO ][discovery ] [Grim Hunter] elasticsearch/fnXUCLOQQBiC1aR7hhB82Q [2015-12-30 10:15:50,442][INFO ][cluster.service ] [Grim Hunter] new_master {Grim Hunter}{fnXUCLOQQBiC1aR7hhB82Q}{127.0.0.1}{127.0.0.1:9300}, reason: zen-disco-join(elected_as_master, [0] joins received) [2015-12-30 10:15:50,491][INFO ][node ] [Grim Hunter] started [2015-12-30 10:15:50,526][INFO ][gateway ] [Grim Hunter] recovered [0] indices into cluster_state
ElasticSearch後端啓動命令
./elasticsearch -d

解決方法2:

在執行elasticSearch時加上參數-Des.insecure.allow.root=true,完整命令以下 

  1. ./elasticsearch -Des.insecure.allow.root=true  
解決辦法3:

用vi打開elasicsearch執行文件,在變量ES_JAVA_OPTS使用前添加如下命令 

  1. ES_JAVA_OPTS="-Des.insecure.allow.root=true"  
以下圖所示,這個方法的好處是之後不用添加參數就能以root身份執行了ps:方法2、三隻對elesticSearch2.x有效
相關文章
相關標籤/搜索