在linux中安装sonar

来源:互联网 发布:微贷网高收益网络理财 编辑:程序博客网 时间:2024/06/07 11:22

一、安装配置sonar

1、Sonar介绍

Sonar是一个用于代码质量管理的开源平台,用于管理Java源代码的质量。通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具,比如pmd-cpd、checkstyle、findbugs、Jenkins。通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方便地对不同规模和种类的工程进行代码质量管理。

同时 Sonar 还对大量的持续集成工具提供了接口支持,可以很方便地在持续集成中使用 Sonar。

此外,Sonar 的插件还可以对 Java 以外的其他编程语言提供支持,对国际化以及报告文档化也有良好的支持。

注意:安装sonar前, 请确保安装好了jdk和MySQL,jdk版本为7.0+,mysql为5.6+,sonar为5.6.6

2、配置数据库

Apache Derby 是Sonar自带并且默认安装使用的数据库,此外Sonar对如下数据库提供支持:MySQL 5.x, Oracle 10g XE, Postgresql, MS SqlServer等,本文以mysql为例介绍如何配置数据库:

1) 配置mysql

结合 SonarQube, MySQL 数据库最好使用 InnoDB 引擎, 可提高性能。 看你的 mysql 现在已提供什么存储引擎:
mysql> show engines;

看你的 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%最佳。

设置方法: 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

3、安装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=9090

保存以上配置(注意,要看看默认的 9090 端口是否已被占用)
防火墙中打开 9090 端口:
vi /etc/sysconfig/iptables
-A INPUT -m state –state NEW -m tcp -p tcp –dport 9090 -j ACCEPT
重启防火墙, 使端口配置生效
service iptables restart
启动 SonarQube Web Server
/root/sonarqube/bin/Linux-x86-64/sonar.sh start( 初次启动会自动建表和做相应的初始化)

浏览器中输入: http://192.168.4.221:9090/sonarqube/

0 0