持续集成之jenkins

代码部署规划

安装jenkins

yum -y install java-1.8.0
cd /etc/yum.repos.d/
wget http://pkg.jenkins.io/redhat/jenkins.repo
rpm --import http://pkg.jenkins.io/redhat/jenkins.io.key
yum install -y jenkins
systemctl start jenkins

访问

http://ip:8080/

安装插件(默认安装即可)

设置用户名和密码 admin lym5401061

安装参考https://www.unixhot.com/article/55

安装支持gitlab插件

 PS:插件目录/var/lib/jenkins/plugins jenkins就是通过使用不同插件实现功能

新建一个项目

PS:配置git前需要配置ssh-key验证(参考git学习)

认证配置方式参考jenkins之配置git认证方式

保存,点击立即构建

PS:构建以后把代码放在/var/lib/jenkins/workspace/demo目录

使用控制台输出可以看到构建执行过程

 构建下载代码以及工作目录为 /var/lib/jenkins/workspace/项目名称 

可以设置构建操作以后的shell也是在这个目录执行的,例如执行以下rsync命令就把代码发布到主机的网站目录里面了(需要提前设置好免密码登录)

持续代码质量管理-Sonar部署

Sonar 是一个用于代码质量管理的开放平台。通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具。与持续集成工具(例如 Hudson/Jenkins 等)不同,Sonar 并不是简单地把不同的代码检查工具结果(例如 FindBugs,PMD 等)直接显示在 Web 页面上,而是通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方便地对不同规模和种类的工程进行代码质量管理。
        在对其他工具的支持方面,Sonar 不仅提供了对 IDE 的支持,可以在 Eclipse 和 IntelliJ IDEA 这些工具里联机查看结果;同时 Sonar 还对大量的持续集成工具提供了接口支持,可以很方便地在持续集成中使用 Sonar。
此外,Sonar 的插件还可以对 Java 以外的其他编程语言提供支持,对国际化以及报告文档化也有良好的支持。

安装参考:https://www.unixhot.com/article/56

[root@linux-node2 ~]# yum install -y java-1.8.0
[root@linux-node2 ~]# cd /root/tools
# wget https://sonarsource.bintray.co ... 6.zip
[root@linux-node2 src]# unzip sonarqube-5.6.zip
[root@linux-node2 src]# mv sonarqube-5.6 /usr/local/
[root@linux-node2 src]# ln -s /usr/local/sonarqube-5.6/ /usr/local/sonarqube

准备Sonar数据库

mysql> CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci;
mysql> GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY '123456';
mysql> GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY '123456';
mysql> FLUSH PRIVILEGES;

配置Sonar

[root@linx-node2 ~]# cd /usr/local/sonarqube/conf/
[root@linx-node2 conf]# ls
sonar.properties  wrapper.conf

编写配置文件,修改数据库配置

[root@linx-node2 conf]# vim sonar.properties
sonar.jdbc.username=sonar
sonar.jdbc.password=sonae@pw
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance

启动Sonar
    你可以在Sonar的配置文件来配置Sonar Web监听的IP地址和端口,默认是9000端口。

[root@linx-node2 conf]# vim sonar.properties
sonar.web.host=0.0.0.0
sonar.web.port=9000
[root@linx-node2 ~]# /usr/local/sonarqube/bin/linux-x86-64/sonar.sh start

访问Sonar
    http://IP:9000

登录用户名和密码为admin admin

安装中文包

PS:安装完在页面重启,需要分析上面语言就要安装该语言的插件比如PHP,Python等 默认带java

PS:MySQL版本要求5.6以上,否则启动Sonar失败

PS:sonar默认插件位置

/usr/local/sonarqube/extensions/plugins

 

下载sonar-scanner(用于扫描代码)

https://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner

解压,配置

列子代码下载https://github.com/Sonarsource

在下载的测试代码文件夹执行命令 sonar-scanning-examples-master.zip

 /usr/local/sonar-scanner/bin/sonar-scanner

在web页面就能看到扫描结果了

 

  jenkins与sonar结合

  jenkins系统管理-系统配置

  系统管理-全局工具配置 添加scanner

  修改构建配置

  点击立即构建

  控制台输出(之前已经看过)

   代码扫描

  返回工程查看代码分析

  就会切换到代码分析的图

  构建后操作

  

  新建一个项目

原文地址:https://www.cnblogs.com/minseo/p/6942134.html