gitlab+jenkins+maven+docker持续集成(十一)——sonarqube及sonarscanner代码审查

简介:

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

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

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

一、安装配置sonarqube

下载地址:

https://sonarsource.bintray.com/Distribution/sonarqube/sonarqube-6.5.zip


1)创建数据库

1
2
3
4
5
6
CREATE DATABASE sonarCHARACTER SET utf8COLLATE utf8_general_ci;
  
CREATE USER  'sonar'  IDENTIFIEDBY  'sonar' ;
GRANT ALL ON sonar.*TO  'sonar' @ '%'  IDENTIFIEDBY  'sonar' ;
GRANT ALL ON sonar.*TO  'sonar' @ 'localhost'  IDENTIFIEDBY  'sonar' ;
FLUSHPRIVILEGES;

2)配置sonarqube

解压后进入conf/sonar.properties


1
2
3
sonar.jdbc.username=sonar
sonar.jdbc.password=sonar
sonar.jdbc.url=jdbc:mysql: //localhost :3306 /sonar ?useUnicode= true &characterEncoding=utf8&rewriteBatchedStatements= true &useConfigs=maxPerformance&useSSL= false

3)配置环境变量

1
2
3
vi  /etc/profile
export  SONAR_HOME= /data/sonar
export  PATH=${SONAR_HOME} /bin :${PATH}

4)启动

1
2
3
cd  bin /linux-x86-64
. /sonar .sh start
. /sonar .sh stop

访问 http://ip:9000 即可


二、安装配置sonar-scanner

1)安装及配置

1
2
3
4
5
6
7
8
9
10
11
12
wget  https: //repo1 .maven.org /maven2/org/sonarsource/scanner/cli/sonar-scanner-cli/3 .0.3.778 /sonar-scanner-cli-3 .0.3.778.zip 
 
解压后进入目录
# more conf/sonar-scanner.properties
#Configure here general information about the environment, such as SonarQube DB details for example
#No information about specific project should appear here
 
#----- Default SonarQube server
sonar.host.url=http: //192 .168.12.109:9000
 
#----- Default source code encoding
sonar.sourceEncoding=UTF-8


2)配置环境变量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#vi /etc/profile
export  SONAR_RUNNER_HOME= /data/sonar-scanner
export  PATH=$SONAR_RUNNER_HOME /bin :$PATH
 
#source /etc/profile
 
确诊生效
# sonar-scanner -h
INFO: 
INFO: usage: sonar-scanner [options]
INFO: 
INFO: Options:
INFO:  -D,--define <arg>     Define property
INFO:  -h,--help             Display help information
INFO:  - v ,--version          Display version information
INFO:  -X,--debug            Produce execution debug output


三、jenkins集成sonar-scanner

1)配置sonar

jenkins 安装 SonarQube Scanner for Jenkins

安装后进入填写sonar信息,新版本是用token进入认证的

用admin进入sonar 用户-->安全, 生成token

wKioL1nIfWPApwMTAADL24de5N0830.png-wh_50



2)sonar scaner环境变量配置

wKiom1nIfiSz-W6-AAB5eHbqNn8626.png-wh_50


配置完以下,我们进入项目中集成

wKiom1nIfp_B27mwAABM5r8n0Vc401.png-wh_50

一下步要注意下,我们选择在构建前,还是构建后进行代码扫描,我这里项目是maven编译后再做代码扫描,所以是构建后,这里要注意下

Post Steps

wKioL1nIftzxo0sDAABZtfv7TjQ366.png-wh_50

1
2
3
4
5
6
sonar.projectKey=platform-batch_dev
sonar.projectName=platform-batch_dev
sonar.projectVersion=1.0 
sonar.language=java
sonar.sources=src /main/java
sonar.java.binaries=target /classes


以上配置完后就可以了, 点项目构建,就会调用sonarscannere脚本,scanner脚本再调用sonar写入到数据库中,构建完成后,我们就会在sonar里看到代码报告了。


wKioL1nIf6axTABhAAC8u37cIgU892.png-wh_50


本文转自 jackjiaxiong 51CTO博客,原文链接:http://blog.51cto.com/xiangcun168/1968394



相关文章
|
27天前
|
jenkins Java 持续交付
运用Jenkins实现Java项目的持续集成与自动化部署
在新建的Jenkins Job中,我们需要配置源码管理,通常选择Git、SVN等版本控制系统,并填入仓库地址和凭据。接着,设置构建触发器,如定时构建、轮询SCM变更、GitHub Webhook等方式,以便在代码提交后自动触发构建过程。
61 2
|
1月前
|
前端开发 安全 数据库
Web架构&前后端分离站&Docker容器站&集成软件站&建站分配
Web架构&前后端分离站&Docker容器站&集成软件站&建站分配
120 1
|
19天前
|
jenkins Java 测试技术
实现基于Jenkins的持续集成与部署
实现基于Jenkins的持续集成与部署
|
12天前
|
Kubernetes Cloud Native 持续交付
云原生架构的核心组成部分通常包括容器化(如Docker)、容器编排(如Kubernetes)、微服务架构、服务网格、持续集成/持续部署(CI/CD)、自动化运维(如Prometheus监控和Grafana可视化)等。
云原生架构的核心组成部分通常包括容器化(如Docker)、容器编排(如Kubernetes)、微服务架构、服务网格、持续集成/持续部署(CI/CD)、自动化运维(如Prometheus监控和Grafana可视化)等。
|
17天前
|
安全 容灾 jenkins
Java面试题:什么是Jenkins以及它在持续集成中的作用?Jenkins有哪些缺点呢?
Java面试题:什么是Jenkins以及它在持续集成中的作用?Jenkins有哪些缺点呢?
25 0
|
1月前
|
jenkins Java 持续交付
蓝易云 - 从零开始配置Jenkins与GitLab集成:一步步实现持续集成
以上就是从零开始配置Jenkins与GitLab集成的步骤,希望对你有所帮助。
56 2
|
1月前
|
Cloud Native jenkins Java
使用Jenkins实现持续集成与持续部署
【6月更文挑战第7天】本文介绍了如何使用Jenkins实现持续集成与持续部署,提高软件开发效率和质量。首先,解释了CI/CD的概念,持续集成通过自动化构建和测试减少错误,持续部署则自动将软件部署至生产环境。接着,详细阐述了Jenkins的安装配置、构建项目设置,以及如何通过代码提交触发构建、自动化测试和构建报告。此外,还讨论了Jenkins的持续部署功能,包括配置部署环境、自动化部署和回滚策略。最后,指出Jenkins在DevOps和云原生趋势中的重要角色。
|
26天前
|
Java jenkins 持续交付
Jenkins是开源CI/CD工具,用于自动化Java项目构建、测试和部署。通过配置源码管理、构建触发器、执行Maven目标,实现代码提交即触发构建和测试
【7月更文挑战第1天】Jenkins是开源CI/CD工具,用于自动化Java项目构建、测试和部署。通过配置源码管理、构建触发器、执行Maven目标,实现代码提交即触发构建和测试。成功后,Jenkins执行部署任务,发布到服务器或云环境。使用Jenkins能提升效率,保证软件质量,加速上线,并需维护其稳定运行。
66 0
|
2月前
|
Linux 应用服务中间件 网络安全
linux安装Gitlab
linux安装Gitlab
131 0
|
29天前
|
持续交付 开发工具 git
阿里云云效产品使用问题之在云效代码域中gitlab使用docker安装的,迁移时遇到“获取企业信息失败”,是什么原因
云效作为一款全面覆盖研发全生命周期管理的云端效能平台,致力于帮助企业实现高效协同、敏捷研发和持续交付。本合集收集整理了用户在使用云效过程中遇到的常见问题,问题涉及项目创建与管理、需求规划与迭代、代码托管与版本控制、自动化测试、持续集成与发布等方面。