使用sonarqube进行代码review

在一个项目组或者整个公司的开发当中,由于开发人员的开发能力不同,写出的代码或多或少或有很大的差异。并且会不经意间留下很多bug。 如果每周都花时间去看所有人员的编码质量将会是一件非常吃力的事儿,项目经理基本会给累死。所以我们得借助工具。现在市面上代码质量监测工具有很多,今天就来看一下其中比较出名的SonarQube在检查Java项目代码中的使用。

由于sonarqube企业版收费,且高版本的对mysql的兼容不好,今天就以sonarqube6.7.7社区版为例来进行一次代码质量检查。

首先下载安装包,官方下载页面:https://www.sonarqube.org/downloads/

找到下载入口,直接点击下载 ,如下:
在这里插入图片描述
然后将下载好的zip包解压到一个文件夹,进入conf目录,进行相关属性的配置:

这里主要配置数据库。为了方便我们使用mysql数据来存放代码扫描的结果,在sonar.properties文件中做如下配置:

# User credentials.
# Permissions to create tables, indices and triggers must be granted to JDBC user.
# The schema must be created first.
#sonar.jdbc.username=
#sonar.jdbc.password=
sonar.jdbc.username=root
sonar.jdbc.password=123456
#----- Embedded Database (default)
# H2 embedded database server listening port, defaults to 9092
#sonar.embeddedDatabase.port=9092

#----- MySQL 5.6 or greater
# Only InnoDB storage engine is supported (not myISAM).
# Only the bundled driver is supported. It can not be changed.
#sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false

说明:
1 要在你配置的数据库中新建名为sonar(名字可以自定义)的数据库
2 你的机器要有Java环境,我这里是Java1.8.0_231。如果你想自己指定Java,可以在wrapper.conf文件中配置,这里就不做说明了

然后执行命令:C:\softwares\sonarqube-6.7.7\bin\windows-x86-64\StartSonar.bat启动sonar

出现如下画面表示成功启动:
在这里插入图片描述
启动成功后它会给你在sonar数据库中自动创建所有它需要用到的表,如下:
在这里插入图片描述
然后访问默认的管理界面:http://localhost:9000/
默认的账户和密码为 : admin / admin

登录成功之后会有弹出框:
在这里插入图片描述
然后输入自己的标识,点击生产一个专属的身份认证token:
在这里插入图片描述
然后选择自己的项目类型,我这边选择Java + maven
在这里插入图片描述
完成以上步骤后,它给你生成好了检查代码的脚本,选择copy,存下来 。

mvn sonar:sonar -Dsonar.host.url=http://localhost:9000 -Dsonar.login=d4c8e91fadc7c69d60a308db421cbb31cfa2d68c

然后到你的项目根目录中,打开git Bash命令框。执行刚生产的命令 ;等待命令执行完成后,再去http://localhost:9000页面,刷新一下,会发现会出一下刚才扫描的项目结果。如下:
在这里插入图片描述
然后查看扫描出的bug和一些不规范的编码:
在这里插入图片描述

然后就可以开始修复bug和优化编码规范了。

其实sonarqube可以安装很多有用的插件,比如SQL检查,以及阿里的P3C规范检查等等,还可以自定义检查的规则。

在线安装插件:
在这里插入图片描述

好啦,师傅领进门,修行在个人,sonarqube检查代码的基本流程就到这啦。对于bug的处理与追踪,即落地到项目组或者整个公司还是有一定的难度,深入的使用和一些高级用法有兴趣的话去他们官方文档里面去翻吧。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Sonar简介 Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从七个维度检测代码质量 通过插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十几种编程语言的代码质量管理与检测 sonarQube能带来什么? Developers' Seven Deadly Sins 1.糟糕的复杂度分布 文件、类、方法等,如果复杂度过高将难以改变,这会使得开发人员难以理解它们, 且如果没有自动化的单元测试,对于程序中的任何组件的改变都将可能导致需要全面的回归测试 2.重复 显然程序中包含大量复制粘贴的代码是质量低下的 sonar可以展示源码中重复严重的地方 3.缺乏单元测试 sonar可以很方便地统计并展示单元测试覆盖率 4.没有代码标准 sonar可以通过PMD,CheckStyle,Findbugs等等代码规则检测工具规范代码编写 5.没有足够的或者过多的注释 没有注释将使代码可读性变差,特别是当不可避免地出现人员变动时,程序的可读性将大幅下降 而过多的注释又会使得开发人员将精力过多地花费在阅读注释上,亦违背初衷 6.潜在的bug sonar可以通过PMD,CheckStyle,Findbugs等等代码规则检测工具检测出潜在的bug 7.糟糕的设计(原文Spaghetti Design,意大利面式设计) 通过sonar可以找出循环,展示包与包、类与类之间的相互依赖关系 可以检测自定义的架构规则 通过sonar可以管理第三方的jar包 可以利用LCOM4检测单个任务规则的应用情况 检测耦合

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值