SonarQube的介绍

SonarQube是一个管理代码质量的开放平台。

可以从七个维度检测代码质量(为什么要用SonarQube):

(1) 复杂度分布(complexity):代码复杂度过高将难以理解、难以维护

(2) 重复代码(duplications):程序中包含大量复制粘贴的代码是质量低下的表现 (3) 单元测试(unit tests):统计并展示单元测试覆盖率

(4) 编码规范(coding rules):通过Findbugs,PMD,CheckStyle等规范代码编写

(5) 注释(comments):少了可读性差,多了看起来费劲

(6) 潜在的Bug(potential bugs):通过Findbugs,PMD,CheckStyle等检测潜在的bug

(7) 结构与设计(architecture & design):依赖、耦合等

Sonar 可以集成不同的测试工具、代码分析工具、持续集成工具、IDE。

Sonar通过对代码质量分析结果数据进行再加工处理,通过量化的方式来度量代码质量的变化,从而可以方便地对工程进行代码质量管理。 支持的语言包括:Java、PHP、C#、C、Cobol、PL/SQL、Flex 等。

SonarQube平台的组成:

(1) 数据库:存放SonarQube的配置数据、代码质量的快照数据

(2) Web服务:用于查看SonarQube的配置数据、代码质量的快照数据

(3) 分析器:对项目代码进行分析,生成质量结果数据并存入数据库中

(分析器有多种,sonarQube Runner(通用的)、SonarQube Ant Task(用ank继承的项目给通过这个),我们选用 SonarQube Maven Plugin)



source code(代码)传入Analysers(分析器)>Analysers通过该database拿到分析规则,回来分析>将分析后的数据传给database保存起来==>通过server(web管理界面)==>查看最终质量管理的结果

当然eclipse等ide中也能集成sonar

SonarQube的安装

安装简介

安装环境要求说明:

http://docs.sonarqube.org/display/SONAR/Requirements

本教程安装环境:

(1) CentOS 6.6

(2) Oracle JDK 7u72

(3) MySQL5.1

(4) SonarQube-4.5.4 (LTS)

安装步骤:

http://docs.sonarqube.org/display/SONAR/Installing

详细安装过程

IP:192.168.4.221

环境:CentOS 6.6、JDK7、MySQL5.1 、SonarQube-4.5.4(LTS) root 用户操作

准备工作:已安装 JDK7 并配置好了环境变量

1 、安装 MySQL5.1

(可参考前面 SVN 管理平台的 MySQL 安装步骤,如果已安装则无需安装)

# rpm -qa | grep mysql
## 查看该操作系统上是否已经安装了 mysql 数据库, 有的话,可以通过 rpm -e 命令 或者 rpm -e --nodeps 命令来卸载掉
# yum install mysql-server mysql mysql-devel
# service mysqld start
# chkconfig --list | grep mysqld
mysqld 0:off 1:off 2:off 3:off 4:off 5:off 6:off

用上面的命令查看到 MySQL 并没有设置开机启动,所以需要设置开机启动

# chkconfig mysqld on

为了方便远程管理,防火墙中打开 3306 端口

# vi /etc/sysconfig/iptables
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT

重启防火墙,使端口配置生效

# service iptables restart

设置 MySQL 数据库 root 用户的密码:

# mysqladmin -u root password 'wusc.123'

登录数据库:

# mysql -u root -p

MySQL 授权远程访问(先用 root 登录 mysql)

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'wusc.321' WITH GRANT OPTION;
mysql> FLUSH PRIVILEGES;

2、配置 MySQL

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

mysql> show engines;



看你的 mysql 当前默认的存储引擎:

mysql> show variables like '%storage_engine%';

修改 MySQL 存储引擎为 InnoDB, 在配置文件/etc/my.cnf 中的 [mysqld] 下面加入 default-storage-engine=INNODB

 # vi /etc/my.cnf
[mysqld]
 default-storage-engine=INNODB

重启 mysql 服务器

 # service mysqld restart

再次登录 MySQL 查看默认引擎设置是否生效

mysql> show variables like '%storage_engine%';
+---------------------+--------+
 | Variable_name      | Value |
 +--------------------+--------+
 | storage_engine     | InnoDB |
 +--------------------+--------+

innodb_buffer_pool_size 参数值设置得尽可能大一点 这个参数主要作用是缓存 innodb 表的索引,数据,插入数据时的缓冲 默认值:128M,专用 mysql 服务器设置的大小:操作系统内存的 70%-80%最佳。 设置方法:my.cnf 文件[mysqld] 下面加入 innodb_buffer_pool_size 参数

# vi /etc/my.cnf
[mysqld]
innodb_buffer_pool_size = 256M

(我们这里设置为 256M,因为我们的不是专用的 MySQL 数据库服务器,还有很多其他的服 务需要占用系统内存)

设置 MySQL 的查询缓存query_cache_size,最少设置 15M

# vi /etc/my.cnf
[mysqld]
query_cache_type=1
query_cache_size=32M

重启 mysql 服务器

# service mysqld restart

验证缓存设置是否生效:

mysql> show variables like '%query_cache%';
+---------------------------------------------+-----------+
| Variable_name			                      | Value     |
+---------------------------------------------+-----------+
| have_query_cache                         	  |YES		  |
| query_cache_limit                           | 104878    |
| query_cache_min_res_unit            		  |324        |
| query_cache_size			                  |sdf		  |
| query_cache_type						      |on		  |
| query_cache_wlock_invalidate                |off		  |
+---------------------------------------------+-----------+

上面设置query_cache_type=1,这里query_cache_type变成了on

3、创建 sonarqube 数据库(UTF-8 编码)

二、安装 SonarQube 的 Web Server

下载最新 LTS 版的 SonarQube 安装包(当前版本为 sonarqube-4.5.4.zip):

下载地址:http://www.sonarqube.org/downloads/



http://dist.sonar.codehaus.org/sonarqube-4.5.4.zip

下载:

# wget http://dist.sonar.codehaus.org/sonarqube-4.5.4.zip

解压安装:

# 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=wusc.123
#----- MySQL 5.x
//设置mysql连接
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonarqube?useUnicode=true&characterE
ncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance

//允许所有ip访问
sonar.web.host=0.0.0.0
//访问路径名
sonar.web.context=/sonarqube
//访问端口
sonar.web.port=9090

保存以上配置(注意,要看看默认的 9000 端口是否已被占用)

防火墙中打开 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/



登录,默认用户名/密码为 admin/admin



到此,SonarQube 已安装完毕,接下来是对 SonarQube 做相应的配置和使用

详细使用过程

一、SonarQube 的配置(前提,先用 admin 用户登录)

1、 安装中文汉化包:

Setting >> Update Center >> Available Plugins >> LOCALIZATION >> Chinese Pack >> Install



安装完汉化包之后需要重启 SonarQube 才能生效(重启前可顺便把 CheckStyle、PMD 等插件 安装一下)



上图是插件安装成功的图片

# /root/sonarqube/bin/linux-x86-64/sonar.sh restart Stopping SonarQube...
Stopped SonarQube.
Starting SonarQube...
Started SonarQube.

重启完之后刷新 SonarQube:http://192.168.4.221:9090/sonarqube/



汉化成功(注意,汉化包并没有完全汉化),重新登录

2、 MyEclipse/Eclipse 中安装 SonarQube 插件的安装、配置、使用:

http://docs.sonarqube.org/display/SONAR/SonarQube+in+Eclipse

http://docs.sonarqube.org/display/SONAR/Installing+SonarQube+in+Eclipse http://docs.sonarqube.org/display/SONAR/Configuring+SonarQube+in+Eclipse http://docs.sonarqube.org/display/SONAR/Working+with+SonarQube+in+Eclipse

(请参考官方文档操作,在此不作讲解,我们重点讲 SonarQube 结合 Maven 插件的使用)

3、 Maven 分析器插件的配置与使用

http://docs.sonarqube.org/display/SONAR/Installing+and+Configuring+Maven

在 Maven 本地库中的 settings.xml(我这里是 settings_edu.xml)配置文件中的 节点中添加如下配置:

<profile>
    <id>sonar</id>
    <activation>
	<activeByDefault>true</activeByDefault> </activation>
	<properties>
		<!-- Example for MySQL-->
		//修改连接sonar的数据库
		<sonar.jdbc.url>
		jdbc:mysql://192.168.4.221:3306/sonarqube?useUnicode=true&amp;chara cterEncoding=utf8
		</sonar.jdbc.url>
		//mysql的用户名密码
		<sonar.jdbc.username>root</sonar.jdbc.username>
		<sonar.jdbc.password>wusc.321</sonar.jdbc.password>
		<!-- Optional URL to server. Default value is http://localhost:9000 -->
		//这里填写上面浏览器访问sonar客户端的路径
		<sonar.host.url>http://192.168.4.221:9090/sonarqube</sonar.host.url>
	</properties>
</profile>

使用 Maven 分析器进行分析,命令:

纯 Maven 命令:mvn clean install sonar:sonar(客户端)

或者:

MyEclipse 中执行: clean install sonar:sonar(点击到pom.xml文件,右键run as==>maven build==>Goals:clean install sonar:sonar==>Profiles:pom.xml==>run)

(如果你是第一次运行此命令,看执行日志你会发现它会先下载 sonar-runner 等插件)

sonar插件咬嘴jdk1.7以上(设置中的java build path)

成功执行完分析命令后便可到 Web Server(浏览器) 中查看代码质量分析结果数据。

直接刷新页面==>右边的projects下面就出现了项目

点击进去就能看到具体的代码分析了



把所有的项目都构建到sonar上面==>刷新==>项目==>所有项目==>出现所有的项目

4、 配置: (1) 配置 (2) 权限 (3) 系统



上图是一些通用配置,点击java可以自定义一些检测规则,不做详细介绍

上图权限的作用是:因为有一个选项是问题,里面有许多任务,需要指派的人,其中的权限就是在这里分配的

系统中可以批量删除,更新中心是一些可以安装的插件

5、 质量配置介绍(切换默认配置)

质量门(上面选择器中的最右边Quality Gates)



质量配置:



sonar way是一些质量规则,点击sonar awy进入下图



这里是一些规则,比如点击阻断,进入



点击左侧的表亲,右边可以看到问题,比如上图就是阻断类型的说明比较严重

当然可以新建配置,比如



上面没有规则,点击最上面导航栏中的规则,进入规则页面



可以发现有很多规则的标签,点击左侧的某个规则==>active激活==>选择刚刚创建的配置,将这个规则设置为自己认为合适的优先级。

再回到刚才的质量配置页面,发现有了新的规则,如下图所示

当然自带的FindBugs和Sonar way已经能够满足需求了,当然可以将某个配置谁知为默认的。

6、 代码规则介绍(自定义规则)



如上图,在规则页面可以加入规则的详细描述,比如中文描述,自己的理解等,这样等在问题页面查看问题的时候,就能查看到详细的注释了。

7、 问题处理介绍(质量管理的体现)

导航栏中的问题按钮进入。



如图有错误的详细介绍



如图能够对错误进行设置是佛解决,修改严重性,评论等,也可以对错误根据严重性、分配人等进行筛选。

8、 指标

点击其中某个项目进入具体的仪表盘



9、 仪表盘(自定义)

从多种维度展示项目



可以将仪表盘设置的更加绚丽,即点击右上角==>配置控件



添加控件,并且选择项目

tips:最主要的是规则的配置和问题的发现和解决

Dubbo入门到精通学习笔记(五):持续集成管理平台之sonarqube代码质量管理平台的介绍与安装的更多相关文章

  1. 持续集成之②:整合jenkins与代码质量管理平台Sonar并实现构建失败邮件通知

    持续集成之②:整合jenkins与代码质量管理平台Sonar并实现构建失败邮件通知 一:Sonar是什么?Sonar 是一个用于代码质量管理的开放平台,通过插件机制,Sonar 可以集成不同的测试工具 ...

  2. Dubbo入门到精通学习笔记(三):持续集成管理平台之SVN版本管理系统的安装和使用

    文章目录 持续集成管理平台介绍 持续集成介绍 持续集成管理平台的组成 持续集成实践介绍 即将学习 SVN版本管理系统的安装 安装 Subversion + Apache 安装 jsvnadmin 简单 ...

  3. Dubbo入门到精通学习笔记(六):持续集成管理平台之Hudson 持续集成服务器的安装配置与使用

    文章目录 安装Hudson 使用Hudson tips:自动化部署 附录:两个脚本 安装Hudson IP:192.168.4.221 8G 内存(Hudson 多个工程在同时构建的情况下比较耗内存) ...

  4. Dubbo入门到精通学习笔记(九):简易版支付系统介绍、部署(单节点)

    文章目录 部署(单节点) 一.前期准备 二.对部署环境进行规划 创建数据库 调整公共配置文件 应用部署前期准备 部署服务 部署 Web 应用 部署定时任务 一. 工程结构 第三方支付系统架构 pay- ...

  5. Dubbo入门到精通学习笔记(一):Dubbo对传统工程进行改造、注册中心安装(Zookeeper-3.4.6)、工程结构优化

    文章目录 改造思路 样例工程:传统的单工程项目(edu-demo) 模型结构 思路 改成dubbo调用方式后的工程结构 部署环境规划 改造 愚公移山 迁移包 迁移页面: 迁移配置相关 新项目的主要作用 ...

  6. Dubbo入门到精通学习笔记(十三):ZooKeeper集群的安装、配置、高可用测试、升级、迁移

    文章目录 ZooKeeper集群的安装.配置.高可用测试 ZooKeeper 与 Dubbo 服务集群架构图 1. 修改操作系统的/etc/hosts 文件,添加 IP 与主机名映射: 2. 下载或上 ...

  7. Dubbo入门到精通学习笔记(十五):Redis集群的安装(Redis3+CentOS)、Redis集群的高可用测试(含Jedis客户端的使用)、Redis集群的扩展测试

    文章目录 Redis集群的安装(Redis3+CentOS) 参考文档 Redis 集群介绍.特性.规范等(可看提供的参考文档+视频解说) Redis 集群的安装(Redis3.0.3 + CentO ...

  8. Dubbo入门到精通学习笔记(四):持续集成管理平台之Maven私有库和本地库的安装与配置

    文章目录 介绍 Maven私有库和本地库的安装与配置 Nexus安装 Nexus 配置(登录后) 介绍 如果构建的Maven项目本地仓库没有对应的依赖包,那么就会去Nexus私服去下载, 那么如果Ne ...

  9. Dubbo入门到精通学习笔记(二十):MyCat在MySQL主从复制的基础上实现读写分离、MyCat 集群部署(HAProxy + MyCat)、MyCat 高可用负载均衡集群Keepalived

    文章目录 MyCat在MySQL主从复制的基础上实现读写分离 一.环境 二.依赖课程 三.MyCat 介绍 ( MyCat 官网:http://mycat.org.cn/ ) 四.MyCat 的安装 ...

随机推荐

  1. Weblogic console控制台密码更改后导致重启服务失败

    weblogic版本10.3.3.0 更改控制台密码后,服务重启失败,报错如下: ----------------------------------------------------------- ...

  2. 60、saleforce的future方法

    测试future方法的异步执行 public with sharing class FutureSample { //future在自己线程中运行,直到资源可用才运行 @future public s ...

  3. Java第四次作业—面向对象高级特性(继承和多态)

    Java第四次作业-面向对象高级特性(继承和多态) (一)学习总结 1.学习使用思维导图对Java面向对象编程的知识点(封装.继承和多态)进行总结. 2.阅读下面程序,分析是否能编译通过?如果不能,说 ...

  4. Java内部类成员

    内部类可以访问其所有实例成员,实例字段和其封闭类的实例方法.参考如下实例 - 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 2 ...

  5. el-form-item内容过多,及弹窗框宽度属性show-overflow-tooltip设置

    内容过多: :show-overflow-tooltip=true 宽度属性设置: .el-tooltip__popper{ max-width:30% }

  6. Python之变量作用域

    使用 global强制声明为全局变量

  7. C#关键字扫盲——Tuple(元组类) 、ValueTuple(值元组)

    原文:C#关键字扫盲--Tuple(元组类) .ValueTuple(值元组) 版权声明:本文为博主原创文章,随意转载. https://blog.csdn.net/Michel4Liu/articl ...

  8. ollvm 编译

    ollvm 的编译相对 llvm 更简单, 1:下载ollvm代码,去 https://github.com/obfuscator-llvm/obfuscator/tree/llvm-4.0 下载,并 ...

  9. LeetCode Array Easy 167. Two Sum II - Input array is sorted

    Description Given an array of integers that is already sorted in ascending order, find two numbers s ...

  10. suffixes - 列出文件后缀。

    DESCRIPTION [描述] 文件后缀与文件名之间以点(.)间隔,通常包括一个或多个字母. 我们用文件后缀来描述文件的内容.很多标准的实用程序,如编译器,以后缀来识别文件类型. make(1) 就 ...