添加如下内容,sonar默认自带mysql驱动。
sonar.jdbc.username=root
sonar.jdbc.password=11111
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true
sonar.jdbc.driverClassName=com.mysql.jdbc.Driver
新的sonarQbude的表相对旧版来说有了新的改动,升级时候需要把旧的表删除。否则会报以下错。
exception caught on transport layer [[id: 0xc7fbf08e, /127.0.0.1:55381 => /127.0.0.1:9001]], closing connection
java.io.IOException: 远程主机强迫关闭了一个现有的连接。
4.2 启动sonarQube
运行“StartSonar.bat”, 访问9000端口,sonar默认自带了jetty服务器。
默认用户名密码 admin、admin。一些设置和菜单只有在登陆之后才能看到。
因个人9000端口有其他用途,将端口改为9090.
sonar.web.port=9090
4.3汉化sonarQube
官网地址 http://docs.sonarqube.org/display/PLUG/Plugin+Library
将sonar-l10n-zh-plugin-1.13.jar放置于sonarqube-6.2\extensions\plugins下。重启sonarQube。
soanrQube有一些需要到的插件,用于代码分析。
插件介绍
插件的下载地址为:http://docs.codehaus.org/display/SONAR/Plugin+Library
将下载后的插件上传到${SONAR_HOME}extensions\plugins目录下,重新启动sonar。
sonar默认集成了Java Ecosystem插件,该插件是一组插件的合集
(1)Java [sonar-java-plugin]:java源代码解析,计算指标等
(2)Squid [sonar-squid-java-plugin]:检查违反Sonar定义规则的代码
(3)Checkstyle [sonar-checkstyle-plugin]:使用CheckStyle检查违反统一代码编写风格的代码
(4)FindBugs [sonar-findbugs-plugin]:使用FindBugs检查违反规则的缺陷代码
(5)PMD [sonar-pmd-plugin]:使用pmd检查违反规则的代码
(6)Surefire [sonar-surefire-plugin]:使用Surefire执行单元测试
(7)Cobertura [sonar-cobertura-plugin]:使用Cobertura获取代码覆盖率
(8)JaCoCo [sonar-jacoco-plugin]:使用JaCOCO获取代码覆盖率
常用的插件:
(1)JavaScript代码检查:http://docs.codehaus.org/display/SONAR/JavaScript+Plugin
(2)Python代码检查:http://docs.codehaus.org/display/SONAR/Python+Plugin
(3)Web页面检查(HTML、JSP、JSF、Ruby、PHP等):http://docs.codehaus.org/display/SONAR/Web+Plugin
(4)xml文件检查:http://docs.codehaus.org/display/SONAR/XML+Plugin
(5)scm源码库统计分析:http://docs.codehaus.org/display/SONAR/SCM+Stats+Plugin
(6)文件度量:http://docs.codehaus.org/display/SONAR/Tab+Metrics+Plugin
(7)中文语言包:http://docs.codehaus.org/display/SONAR/Chinese+Pack
(8)时间表显示度量结果:http://docs.codehaus.org/display/SONAR/Timeline+Plugin
(9)度量结果演进图:http://docs.codehaus.org/display/SONAR/Motion+Chart+Plugin
(b)插件配置示例(本段内容来自http://www.ibm.com/developerworks/cn/java/j-lo-sonar/
五 sonar-runner安装
5.1 修改sonar-runnerc下的conf的sonar-scanner.properties配置文件
sonar.host.url=http://localhost:9090
sonar.jdbc.username=root
sonar.jdbc.password=11111
sonar.jdbc.url=jdbc:mysql://10.10.5.64:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true
sonar.jdbc.driverClassName=com.mysql.jdbc.Driver
5.2 在项目的根目录下添加文件sonar-project.properties
1 单一个项目
sonar.projectKey=pljj
sonar.projectName=pljj
sonar.projectVersion=1.0-SNAPSHOT
sonar.sources=src/main/java
sonar.tests=src/test/java
sonar.binaries=target/classes
sonar.language=java
2 maven多模块
sonar.projectKey=pljj
sonar.projectName=pljj
sonar.projectVersion=1.0
sonar.sources=.
sonar.language=java
sonar.sourceEncoding=UTF-8
或者
sonar.projectKey=com.pljj-job
sonar.projectName=elastic-job
sonar.projectVersion=1.1.0
# Set modules IDs
sonar.modules=pljj-core,pljj-console,pljj-spring
# Modules inherit properties set at parent level
sonar.sources=src/main/java
sonar.tests=src/test/java
sonar.java.binaries=target
sonar.language=java
5.3,运行sonar-runner
在“开始”》“运行”中输入cmd切换的项目更目录 输入“sonar-runner”
以下为成功目录
登陆http://localhost:9090/ 查看代码扫描结果,帐号密码admin/admin
六 mave安装和sonarQbude配合使用
6.1在maven官网下载maven
http://maven.apache.org/download.cgi
打开cmd窗口数据 mvn –v 查看maven版本,打印如下表示安装成功。
6.2 在%M2_HOME%\conf\setting.xml中输入下面内容(直接用下面的内容覆盖原文件)
sonar
true
jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8
com.mysql.jdbc.Driver
root
11111
http://localhost:9000
使用asonr-maven-plugin进行分析,在项目的pom.xml里面添加
参考官网:
http://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner+for+Maven
org.codehaus.mojo
sonar-maven-plugin
2.7.1
保存后找到你需要被sonar分析的maven项目根目录, 被分析的项目必须带有pom文件
6.3、在CMD窗口下,命令行进入到项目文件的目录中去,然后再输入mvn sonar:soanr进行测试
6.4、在浏览器中输入http://localhost:9000查看结果。
7 ,nexus安装
nexus仓库并不是必须的,不使用私有仓库情况,不必安装。
7.1下载nexus http://www.sonatype.org/nexus/go/ 我的是linux版本
将安装包复制到需要安装的机器,我安装在/opt/soft/nexus tar –zxvf nexus-latest-bundle.tar.gz 解压后会出现两个目录 cd nexus-2.7.7-01/bin ./nexus 输出如下: 列出了nexus的各种命令 ./nexus start 启动服务 然后在本机访问http://localhost:8081/nexus,默认用户名密码:admin,admin123
如果是远程机访问还需要开通8081端口,操作如下:
/sbin/iptables -I INPUT -p tcp --dport 8081 -j ACCEPT #开启8081端口
/etc/rc.d/init.d/iptables save #保存配置
/etc/rc.d/init.d/iptables restart #重启服务
查看端口是否已经开放
/etc/init.d/iptables status
7.2 项目本地pom.xml配置
4.0.0
pljj-common
pljj-core
pljj-report
com.pljj
pljj-pom
0.0.1-SNAPSHOT
pom
pljj-pom
http://maven.apache.org
UTF-8
com.pljj
0.0.1-SNAPSHOT
3.2.9.RELEASE
3.6.2
2.9.0
2.0.6
1.2.1
commons-beanutils
commons-beanutils
1.9.2
org.apache.commons
commons-lang3
3.1
commons-cli
commons-cli
1.2
commons-codec
commons-codec
1.6
commons-io
commons-io
2.2
commons-net
commons-net
3.3
commons-fileupload
commons-fileupload
1.3.1
commons-dbcp
commons-dbcp
1.3
org.apache.ant
ant
1.8.4
org.apache.lucene
lucene-core
${lucene.version}
org.apache.lucene
lucene-analyzers
${lucene.version}
org.apache.lucene
lucene-highlighter
${lucene.version}
org.apache.lucene
lucene-memory
${lucene.version}
org.apache.lucene
lucene-queries
${lucene.version}
org.springframework
spring-core
${spring.version}
org.springframework
spring-context-support
${spring.version}
org.springframework
spring-web
${spring.version}
org.springframework
spring-webmvc
${spring.version}
org.springframework.data
spring-data-commons-core
1.4.1.RELEASE
org.springframework.data
spring-data-jpa
1.2.0.RELEASE
org.slf4j
slf4j-api
1.7.2
ch.qos.logback
logback-classic
1.0.7
ch.qos.logback
logback-core
1.0.7
org.freemarker
freemarker
2.3.19
com.mysema.querydsl
querydsl-jpa
${querydsl.version}
com.mysema.querydsl
querydsl-lucene
${querydsl.version}
org.hibernate
hibernate-core
3.6.10.Final
org.hibernate
hibernate-entitymanager
3.6.10.Final
org.hibernate.javax.persistence
hibernate-jpa-2.0-api
1.0.1.Final
org.hibernate
hibernate-validator
4.2.0.Final
org.apache.shiro
shiro-web
${shiro.version}
org.apache.shiro
shiro-ehcache
${shiro.version}
org.apache.shiro
shiro-spring
${shiro.version}
com.octo.captcha
jcaptcha
2.0-alpha-1
org.imgscalr
imgscalr-lib
4.2
com.jhlabs
filters
2.0.235
com.fasterxml.jackson.core
jackson-annotations
${jackson.version}
com.fasterxml.jackson.core
jackson-core
${jackson.version}
com.fasterxml.jackson.core
jackson-databind
${jackson.version}
com.fasterxml.jackson.dataformat
jackson-dataformat-xml
${jackson.version}
org.htmlparser
htmlparser
1.6
joda-time
joda-time
2.1
com.oracle
ojdbc14
10.2.0.3.0
org.aspectj
aspectjweaver
1.7.2
javax.servlet
servlet-api
2.4
provided
org.apache.httpcomponents
httpcore
4.3.2
org.apache.httpcomponents
httpclient
4.3.2
org.codehaus.woodstox
stax2-api
4.0.0
org.quartz-scheduler
quartz
2.1.7
junit
junit
3.8.1
test
nexus
Releases
http://私服ip:8081/repository/maven-releases
nexus
Snapshot
http://私服ip:8081/repository/maven-snapshots
compile
page
org.apache.maven.plugins
maven-surefire-plugin
2.6
true
org.apache.maven.plugins
maven-compiler-plugin
2.1
1.6
1.6
7.3 maven配置,修改conf下的setting.xml
org.sonatype.plugins
nexus
admin
admin123
nexus
*
http://私服ip:8081/repository/maven-public/
repo2
central
Human Readable Name for this Mirror.
http://repo2.maven.org/maven2/
nexus
central
http://私服ip:8081/repository/maven-central
true
true
central
http://私服ip:8081/repository/maven-central
true
true
nexus
然后执行mvn clean deploy
八 jenkins,sonar和 maven集成
8.1 jenkins安装
1,Jenkins的默认工作间在C:\Users\xxxxxx.jenkins,修改工作空为间D:\jenkins,只需要添加环境变量 JENKINS_HOME=D:\jenkins
2,从jenkins官网下载jenkins:https://wiki.jenkins-ci.org/display/JENKINS/Meet+Jenkins点击“download jenkins.war”
下载的为jenkins.zip将其更改为jenkins.war包,有两种运行方式 a. 运行 java -jar jenkins.war,采用内置jetty服务器。
b. 将下载的war包文件部署到 servlet 容器,然后启动容器(推荐这种方式)。 用浏览器打开http://localhost:8080/ jenkins,访问Jenkins主页。
8.2 修改jenkins配置
为了让jenkins
可以在构建项目的时候执行sonar
,所以我们需要在jenkins上安装插件 。
同时为了可以使用svn,maven,email也同样需要安装插件。
现在就可以进行配置,让jenkins和sonar结合在一起。这样我们构建项目的时候就会进行代码检测
1,系统设置
1)全局属性 -Tool Locations
2) SonarQube servers
3) Jenkins Location
3) Extended E-mail Notification
邮件配置中的密码均为,邮件的takens,直接stmp的端口,还是回不能成功,连接不到,改为ssl,端口为465。成功发送邮件。
参考 https://zhuanlan.zhihu.com/p/22810691。
4) 邮件通知
可以通过这个功能测试邮件是否可以正常使用。
用户名不带@163.com,使用ssl,465端口。在不勾选情况下,使用smtp的25端口发送失败。
2 Global Tool Configuration
点击“系统管理”页面,点击Global Tool Configuration。
增加jdk,maven,sonar-runner等环境地址。如jdk,点击新增,去掉【自动安装】的勾选。
配完后点击保存。
7.4 构建一个自由风格的项目
1)增加svn的url和需要密码验证是后输入帐号密码
2)构建触发器,3分钟触发一次
3)构建 编辑我们的项目,选择最下放。找到构建
Not authorized. Please check the properties sonar.login and sonar.password.
4)sonarQbude必须把sonar-project.properties的内容粘贴进来。否则构建时候,会报异常,
5)构建后操作.增加一个邮件通知的管理。
转载自:
https://zhuanlan.zhihu.com/p/22810691
进入到具体的某一job中配置邮件通知
选择html
点击“add trigger”选择awyas
(本邮件是程序自动下发的,请勿回复!)
项目名称:$PROJECT_NAME
构建编号:test_$BUILD_NUMBER
svn版本号:${SVN_REVISION}
构建状态:$BUILD_STATUS
触发原因:${CAUSE}
构建日志地址:${BUILD_URL}console
构建地址:$BUILD_URL
变更集:${JELLY_SCRIPT,template="html"}
将构建日志压缩作为附件也添加到邮件当中发送,需要注意的是,每一次构建都会产生一个报告文档,仓库里会包含有之前构建的所有的报告文档,
所以需要打包的是当前这次产生的报告文档,不是之前的构建产生的文档点击应用“apply”,然后保存
八 构建项目
填写完毕后,我们点击保存
点击开始构建,则开始构建job,点击sonarQbude可以查看分析的结果。点击具体的构建记录可以看到
构建的日志。
Build History的#50,#49可以看到构建的日志。