**环境准备 **

内置数据库

Sonar安装成功后,默认内置H2数据库,用于记录单次的扫描结果,对同一个project重复扫码,会覆盖之前的扫描记录,所以H2 数据库只应用于测试,不可以用于生产环境,那如果你是想玩玩,不想长期扫描你的项目,可以不必配置数据库

自定义数据库:

  • Oracle
  • SQL Server(只支持SQL Server 2014 以及 SQL Server2016)
  • PostgreSQL
  • MYSQL 版本限制: 8.0>MYSQL>=5.6

(注官方说明,从Sonar7.9版本,不再支持Mysql),以下链接
**End of Life of MySQL Support : SonarQube 7.9 and future versions do not support MySQL.
Please migrate to a supported database. Get more details at **
https://community.sonarsource.com/t/end-of-life-of-mysql-support
https://jira.sonarsource.com/browse/SONAR-11963

安装步骤

1.安装sonarqube:

安装的是windows 7.4 community社区版
https://binaries.sonarsource.com/Distribution/sonarqube/sonarqube-7.4.zip
我之前是用最新的8.2版本,不过问题很多,而且评价说最新的不是很稳定,不支持mysql,最后使用的7.4版本,
官网下载比较慢,大家如果无法下载可以留言回复我,或者关注文末二维码私信我。

2.安装JDK:

我安装的JDK11(1.8版本无法安装最新的sonarqube 8.2,7.x是可以的,大家选择时候需要注意)
如果无法找到下载地址,私信我。

3.选择数据库

4.配置:

  1. 安装完毕,打开此目录,运行StartSonar.bat

2.启动浏览器,访问http://localhost:9000 , 如出现下图则表示安装成功。

3.配置连接数据库 :
打开conf文件夹下的sonar.properties文件,底部追加如下:

如果是SQL Server,追加:

  • sonar.jdbc.url=jdbc:sqlserver://10.60.215.202;databaseName=sonar
  • sonar.jdbc.username=sa
  • sonar.jdbc.password=123456

如果是MYSQL:

  • sonar.jdbc.url=jdbc:mysql://10.60.253.34:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance&useSSL=false
  • sonar.jdbc.username=root
  • sonar.jdbc.password=123456
  • sonar.sorceEncoding=UTF-8
  • sonar.login=admin
  • sonar.password=admin

    4.重启,即重新运行StartSonar.bat,使用admin ,admin登陆系统。配置数据库之后,会初始化表信息,耐心等待一段时间。

5.Sonar中创建project ,并配置命令

5.在IDEA中进到要扫描的项目根目录,执行: mvn sonar:sonar \ -Dsonar.projectKey=test_project \ -Dsonar.host.url=http://10.60.25.121:9000 \ -Dsonar.login=6dc9cd89575d252d12d450267a64c0ee4bca3c65

扫描结果:

这里扫码的时候,IDEA提示lifecycle-mapping jar包找不到,使用这个方式安装一下就好

git clone https://github.com/mfriedenhagen/dummy-lifecycle-mapping-plugin.git , 然后mvn package即可安装这个缺失的包。

集成阿里巴巴p3c

该指南整合了阿里巴巴集团技术团队多年来的最佳编程实践。 随着我们鼓励重用和更好地理解彼此的程序,大量的Java编程团队对项目之间的代码质量提出了苛刻的要求。 过去我们已经看到许多编程问题。 例如,有缺陷的数据库表结构和索引设计可能会导致软件体系结构缺陷和性能风险。 另一个例子是难以维护的混乱代码结构。 此外,未经身份验证的易受攻击的代码容易受到黑客的攻击。 为了解决这类问题,我们在阿里巴巴为Java开发人员开发了本文档。alibaba p3c 地址: https://github.com/alibaba/p3c

如何应用该指南来规范我们的项目代码呢,我们可以在sonar中引入sonar-p3c这个开源插件,下面介绍下详细步骤:

build sonar-p3c plugin插件:

sonar 7.4版本,一定要参照如下链接: https://github.com/rhinoceros/sonar-p3c-pmd/releases/tag/pmd-3.2.0-beta-with-p3c1.3.6-pmd6.10.0 , 100%无问题。

具体步骤

a.打包branch

git clone --single-branch --branch p3c-pmd-1.3.6-branch https://github.com/rhinoceros/p3c.git

clone下来之后,打包

mvn clean install -Dgpg.skip=true

b.打包plugin

git clone https://github.com/rhinoceros/sonar-p3c-pmd/tree/pmd-3.2.0-beta-with-p3c1.3.6-pmd6.10.0

clone下来之后,打包

mvn clean package

部署p3c插件

将上一步打好的jar包 ,放到sonar extensions/plugins下,重启SonarQube

点击Quality Proifles,并点击Create

选择Java并命名

点击Active More

左侧filter搜索p3c,并选择Bulk Change,将p3c规则加入刚创建的profile中

回到Quality Profiles,设置刚刚的profile为默认

到此,p3c规则成功集成到Sonar中。现在测试下:

点击Create new project

选择Java,并生成token,生成mvn命令,Copy,直接在项目里执行即可

Idea中扫描会很快,Sonar中会一直显示In Progress,需要等一会才有分析结果。成功执行后结果如下,说明p3c已经成功检查我们的代码

------------------------------------------ END ------------------------------------------------------

刚刚开始写文章,还望老哥点赞推荐下。

更多好文,关注作者:

sonarqube配置全指南,集成阿里巴巴p3c规范相关推荐

  1. HTC VIVE Focus Wave VR SDK 新手入门开发配置全指南 Development Tutorial

    文章目录 配置Android开发环境 下载 & 安装Java 8 SDK 配置Android SDK 安装Unity 安装Unity Hub 安装Unity 2018.4.4f1 配置Unit ...

  2. .net xml ajax 注册 ashx,AJAX.NET安装配置全指南

    Ajax.NET安装配置:下载与安装 首先从 AJAX.NET 项目网站上下载并解压缩 AJAX 文件,然后按照您的喜好在 Visual Basic .NET 或 C# 中创建新的 ASP.NET 项 ...

  3. SonarQube 9.x集成阿里p3c代码规范检测java代码;

    文章目录 前言 一.下载p3c-pmd插件 二.sonarqube配置使用p3c规则检测 1.新建质量配置 2.将创建好的p3c检测规则设置为默认质量配置 注1 注2 前言 因为我们公司后端主用的是j ...

  4. 《阿里巴巴编码规范(JAVA)》学习认证考后感

    image.png <阿里巴巴 Java 开发手册>是阿里巴巴集团技术团队的集体智慧结晶和经验总结,经历了多次大规模一线实战的检验及不断完善,系统化地整理成册,回馈给广大开发者. 本手册的 ...

  5. 01配置管理过程指南

    为什么80%的码农都做不了架构师?>>>    01配置管理过程指南 1 综述 1.1 前言 本指南的编写,是为了指导软件开发团队对软件过程中的程序.文档等配置项进行明确的.量化的管 ...

  6. 9.9的阿里巴巴编码规范考试竟如此简单?搜集试题分享!让我们一起守护开发规范!

    很早就买了阿里巴巴编码规范的考试,但是因为那一段时间太忙了,居然就把自己买的这个考试给忘记了,就在上周手机突然收到短信提醒我阿里巴巴编码规范再有30天就要到期了.吓得我赶紧趁着上班之余把手册看看,手册 ...

  7. idea安装阿里巴巴java规范插件(代码质量管理)安装和使用

    一.插件发布背景 2017年10月14日上午9:00  阿里巴巴于在杭州云栖大会<研发效能峰会>上,正式发布<阿里巴巴Java开发手册>扫描插件,该插件在扫描代码后,将不符合& ...

  8. 神器 VS Code,超详细Python配置使用指南

    作者:Lemon 出品:Python数据之道 神器 VS Code, 超详细Python配置使用指南 大家好,我是 Lemon. 之前在公众号发了关于 PyCharm 与 VS Code 对比的文章, ...

  9. sonarqube中怎么添加阿里java开发规范

    这篇文章给大家介绍sonarqube中怎么添加阿里java开发规范,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助. 1.拉取sonar-pmd源码,切换到3.2.1.修改pom文件 ...

  10. 阿里巴巴代码规范学习+redis stream

    阿里巴巴代码规范学习 1.volatile volatile是一个特征修饰符(type specifier).volatile的作用是作为指令关键字,确保本条指令不会因编译器的优化而省略,且要求每次直 ...

最新文章

  1. 数据结构(Data structures)(二):结构体指针
  2. 从JDBC ResultSet创建对象流
  3. Linux 的权限表达式
  4. clodeblocks debug断点调试_idea debug调试————简单常用,适合初学者
  5. idea中git分支、合并与使用
  6. React的单向数据流与组件间的沟通
  7. 《编写可维护的JavaScript》——2.2 多行注释
  8. 【博客管理】博客新建栏目的添加—HTML格式书写规范
  9. C空间不够如何盘瘦身
  10. win10 物理按键映射、快捷键修改
  11. 培训机构刷题小程序设计与制作
  12. 单细胞测序在免疫治疗研究中的应用
  13. 齐齐哈尔计算机应用软件学校,齐齐哈尔职业学院计算机应用技术专业介绍
  14. sublime - sublimerge 文本比较插件
  15. 一篇文章解决所有的 #如何下载安装xshell链接VMware虚拟机liunx系统(如SentOS,ubuntu等等)# 等问题
  16. 黑马程序员学习笔记-------c++提高编程
  17. Java——上溯造型下溯造型
  18. 用python pynput 监听键盘输入
  19. unity绑定骨骼动画 使用现成的模型和动作库
  20. 股票自选股程序编辑简介

热门文章

  1. 爬虫爬取全国地名的中文和拼音
  2. 现代信号处理——自适应滤波器(离散维纳滤波器)
  3. 卸载vuecli3_针对遇到安装或卸载vue-cli失败的解决方案
  4. Mac中Word 2016导出PDF附带书签目录结构
  5. 【预测模型】基于遗传算法优化最小二乘支持向量机lssvm实现数据预测matlab代码
  6. Verilog的基本语法
  7. 【行业案例分析】3C数码行业B2B供应链平台开发案例
  8. 天轰穿&甜老丝儿 python浅显易懂全教程
  9. 计算机钢琴键盘,Everyone Piano
  10. 南开计算机等级,南开100题分类-全国计算机等级考试上机考试习题集(二级C)(南开大学出版社)...