Jenkins

文章目录

  • Jenkins
  • Jenkins简介
  • SVN介绍
  • Maven介绍
  • Ant介绍
  • Gradle介绍
  • jenkins工作原理
  • CI/CD是什么
  • CI持续集成简介
  • CI工作模式
  • 持续集成的优势
  • CD持续交付
  • CD 持续交付简介
  • CD工作模式
  • CD 持续部署简介
  • 基于Tmocat容器部署Jenkins
  • 部署Tomcat
  • 安装Tomcat
  • 部署Jenkins
  • 安装Jenkins
  • 自定义Jenkins
  • 环境准备工作
  • 全局工具配置
  • Jenkins流水线项目发布流程
  • 项目环境准备
  • 安装工具包
  • 发布流水线——脚本方式
  • 使用脚本创建
  • 第一阶段————项目克隆
  • 第二阶段————生成站点
  • 第三阶段————scp的方式发送给Masters_A
  • 发布流水线——文本参数方式

Jenkins简介

官方链接

Jenkins是一个开源CI&CD软件、提供友好操作界面的持续集成(CI)工具;
起源于Hudson(Hudson是商用的),主要用于持续、自动的构建/测试软件项目、监控外部任务的运行;Jenkins用Java语言编写,可在Tomcat等流行的servlet容器中运行,也可独立运行;通常与版本管理工具(SCM)、构建工具结合使用。

常用的版本控制工具:SVN、GIT
构建工具有:Maven、Ant、Gradle

SVN介绍

SVN是subversion的缩写,是一个开放源代码的版本控制系统,通过采用分支管理系统的高效管理,简而言之就是用于多个人共同开发同一个项目,实现共享资源,实现最终集中式的管理。

Maven介绍

Maven 就是构建 java 里面的一个 war 包的;
Maven 项目对象模型(POM)是可以通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具;
Maven 除了以程序构建能力为特色之外,还提供高级项目管理工具。由于Maven的缺省构建规则有较高的可重用性,所以常常用两三行Maven构建脚本就可以构建简单的项目;
由于Maven的面向项目的方法,许多Apache Jakarta 项目发文时使用Maven,而且公司项目采用Maven的比例在持续增长。

Ant介绍

Ant是一个将软件编译、测试、部署等步骤联系在一起的自动化工具,Ant的主要用途是构建Java应用程序;
Ant提供了许多内置的任务,可以编译、组装、测试和运行Java应用程序。Ant还可以有效地用于构建非Java应用程序,例如C或C++应用程序。

Gradle介绍

Gradle是一个基于Apache Ant和Apache Maven概念的项目自动化构建工具,Gradle就是工程的管理,帮我们做了依赖、打包、部署、发布、各种渠道的差异管理等工作。

jenkins工作原理

将源代码从SVN/Git版本控制系统中拷贝一份到本地,然后根据设置的脚本进行build(构建);整个系统的关键就是build脚本,build脚本告诉Jenkins在一次集成中需要执行的任务。

##jenkins特点

  • (1)易安装:仅仅一个 Jenkins.war,从官网下载该文件后,直接运行,无需额外的安装,更无需安装数据库
  • (2)易配置:提供友好的 GUI 配置界面
  • (3)变更支持:Jenkins 能从代码仓库(SVN/Git)中获取并产生代码更新列表,并输出到编译输出信息中
  • (4)支持永久链接:用户是通过 Web 来访问 Jenkins 的,而这些 Web 页面的链接地址都是永久链接地址,可以在各种文档中直接使用该链接;
  • (5)集成 E-Mail/RSS/IM:当完成一次集成时,可通过这些工具实时收取集成结果(构建一次集成需要花费一定时间,有了这个功能,就可以在等待结果过程中,干别的事情);
  • (6)JUnit/TestNG 测试报告:也就是用以图表等形式提供详细的测试报表功能;
  • (7)支持分布式构建:Jenkins 可以把集成构建等工作分发到多台计算机中完成;
  • (8)文件指纹信息:Jenkins 会保存构建集成所产生的 jars 文件、集成构建使用了哪个版本;
  • (9)支持第三方插件:Jenkins 支持 第三方插件,这使得 Jenkins 功能变得越来越强大。

CI/CD是什么

CI持续集成

CI持续集成简介

CI 持续集成(全称:Continuous integration)
中文意思是持续集成是一种软件开发时间

持续集成强调开发人员提交了新代码之后,立刻进行构建、(单元)测试;根据测试结果,我们可以确定新代码和原有代码能否正确地集成在一起。

假设一个应用程序,其代码存储在GitLab的Git仓库中。开发人员每天都要多次推送代码更改。对于每次向仓库的推送,你都可以创建一组脚本来自动构建和测试你的应用程序,从而减少了向应用程序引入错误的机会。这种做法称为持续集成,对于提交给应用程序(甚至是开发分支)的每项更改,它都会自动连续进行构建和测试,以确保所引入的更改通过你为应用程序建立的所有测试,准则和代码合规性标准。

CI工作模式

Jenkins_持续集成

持续集成的优势

  • (1)易于定位错误:
    每一次的代码集成都需要执行相关的测试工作,持续集成频繁的集成次数天然的将复杂的代码逻辑切割为了小块,也就使得每一次测试中遇到的错误能够更加容易的被定位。
  • (2)易于控制开发流程:
    更为细致的工作提交也就意味着更容易判断当前的工作进度,这对于管理者规划开发流程而言提供了一个有效的参考,同时也为开发人员省下了汇报工作的时间。

CD持续交付

CD 持续交付简介

CD 持续交付(全称:Continuous Delivery)
中文意思是:持续交付

是在 CI持续集成 的基础上,将集成后的代码部署到更贴近真实运行环境(类生产环境)中;

比如,我们完成单元测试后,可以把代码部署到连接数据库的Staging环境中更多的测试,如果代码没有问题,可以继续手动部署到生产环境。

CD工作模式

Jenkins_tomcat_02

#CD持续部署

CD 持续部署简介

CD 持续部署(全称:Continuous Deployment)

是 CI持续集成 ,CD持续交付的延伸。自动将交付的应用部署到生产环境。能及时收到用户反馈,降低部署的风险

持续部署是持续交付的下一步,在持续交付的基础上,由开发人员或运维人员自助式的定期向生产环境部署稳定的构建版本,持续部署的目标是代码在任何时刻都是可部署的,并可自动进入到生产环境。

基于Tmocat容器部署Jenkins

环境说明

主机名称

IP

环境

系统

localhost

192.168.79.134

Tomcat Jenkins

Centos8

部署Tomcat

注意这里下载的9.0版本 10.0版本部署由BUG
下载链接

1-关闭防火墙和Seliux
[root@localhost ~]# systemctl disable firewalld.service 
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@localhost ~]# systemctl stop firewalld.service 
[root@localhost ~]# setenforce 0

安装Tomcat

1-安装java环境
[root@Masters ~]#yum -y install java-11-openjdk
过程......

2-安装Tomcat
[root@Masters ~]# wget https://dlcdn.apache.org/tomcat/tomcat-9/v9.0.67/bin/apache-tomcat-9.0.67.tar.gz
过程......

3-解压到相应目录
[root@localhost ~]# tar -xzf apache-tomcat-9.0.67.tar.gz -C /usr/local/
[root@localhost ~]# cd /usr/local/
[root@localhost local]# ln -s apache-tomcat-9.0.67/ tomcat

4-启动tomcat
[root@localhost local]# cd tomcat/
[root@localhost tomcat]# bin/startup.sh 
[root@localhost tomcat]# ss -anlt
State       Recv-Q      Send-Q                Local Address:Port           Peer Address:Port     Process     
LISTEN      0           128                         0.0.0.0:22                  0.0.0.0:*                    
LISTEN      0           128                            [::]:22                     [::]:*                    
LISTEN      0           1                [::ffff:127.0.0.1]:8005                      *:*                    
LISTEN      0           100                               *:8080                      *:*

部署Jenkins

下载链接

1-在/usr/local/tomcat/webapps/下下载Jenkins

[root@localhost ~]# cd /usr/local/tomcat/webapps/
[root@localhost webapps]#  wget http://mirrors.jenkins.io/war-stable/2.346.3/jenkins.war
过程......

安装Jenkins

1-Jenkins下载后会自动解压目录为jenkins
[root@localhost webapps]# ls
ROOT  docs  examples  host-manager  jenkins  jenkins.war  manager

2-启动jenkins服务
[root@localhost webapps]# cd ..
[root@localhost tomcat]# bin/catalina.sh stop
...
[root@localhost tomcat]# bin/catalina.sh start
...

3-浏览器访问解锁

密码存放地址
[root@localhost tomcat]# cat /root/.jenkins/secrets/initialAdminPassword
a914c6cc663640d9af9dc256662c21a2

Jenkins_运维_03


Jenkins_运维_04

自定义Jenkins

环境准备工作

1-在进入后选择选择插件来安装

Jenkins_jenkins_05

2-选择然后安装 具体在后期情况中需要什么插件就安装什么插件

Jenkins_Jenkins_06


Jenkins_持续集成_07

等安装完成…

3-创建管理员用户

Jenkins_jenkins_08


Jenkins_持续集成_09


Jenkins_运维_10

4-汉化(更换国内源)

原国外插件源地址国内插件源地址

Jenkins_持续集成_11


Jenkins_Jenkins_12

然后点击 Advanced —> 更新为国内源 —> Submit

Jenkins_Jenkins_13

4-1安装简体中文插件

中文简体插件:Localization:Chinese(Simplified)

Jenkins_持续集成_14


Jenkins_Jenkins_15

等待重启完成…

Jenkins_jenkins_16


Jenkins_Jenkins_17

5-安装Git GitHubGitLab Gitee插件**(可以跳过这步)**

安装后之后将重启服务

Jenkins_jenkins_18

6-创建任务

Jenkins_Jenkins_19


Jenkins_jenkins_20


Jenkins_持续集成_21


Jenkins_jenkins_22


Jenkins_tomcat_23

全局工具配置

Jenkins_tomcat_24

Jenkins流水线项目发布流程

主机名称

IP

相关环境

工具包

系统

Masters

192.168.79.134

tomcat jenkins

git maven

Centos8

Masters

192.168.79.135

tomcat


Centos8

项目环境准备

重新安装部署好Tomcat和Jenkins
1-关闭防火墙和Selinux
2-在Masters上部署服务tomcat和jenkins(上面已经部署),重新部署,登录web界面时选择安装推荐的插件,部署好后,设置国内源

安装的时候选择安装推荐的插件

Jenkins_jenkins_25

安装简体中文插件包

Jenkins_jenkins_26

安装工具包

[root@Masters ~]# yum -y install git maven
过程......

发布流水线的方法我在这里给介绍两种
一种是脚本的方式
一种是使用文本参数的方式

发布流水线——脚本方式

脚本内容

1-第一阶段
pipeline { 
	agent any

	stages { 
		stage('pull code') { 
			steps { 
				git 'http://github.com/lizhenliang/tomcat-java-demo.git'
			}
		}
	}
}

2-第二阶段
pipeline { 
	agent any

	stages { 
		stage(‘pull code’) { 
			steps { 
				git ‘http://github.com/lizhenliang/tomcat-java-demo.git’
			}
		}
		stage(‘package’) { 
			steps { 
				sh """ 
				mvn clean
				mvn package
				"""
			}
		}
	}
}

3-第三阶段
pipeline { 
	agent any

	stages { 
		stage(‘pull code’) { 
			steps { 
				git ‘http://github.com/lizhenliang/tomcat-java-demo.git’
		}
	}
	stage(‘package’) { 
		steps { 
			sh """ 
			mvn clean
			mvn package
			"""
		}
	}
	stage('deploy') { 
		steps { 
	         sh """                
	         scp target/ly-simple-tomcat-0.0.1-SNAPSHOT.war root@192.168.79.134:/usr/loc 
	         al/tomcat/webapps/
             ssh root@192.168.79.134 '/usr/local/tomcat/bin/catalina.sh stop && 
             /usr/local/tomcat/bin/catalina.sh start'     
             """
			}
		}
	}
}

在Masters主机上生成密码 传给Masters_A主机

[root@Masters ~]# ssh-keygen 
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Created directory '/root/.ssh'.
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
SHA256:mOJGWNBkRF9pscTJVyz1dv70v2XH8Kro7Kjhzp3XjeU root@Masters
The key's randomart image is:
+---[RSA 3072]----+
|  .==  o++ +o    |
|   o.. o*.o ..   |
|    . .... .  o .|
|   o   o     . o |
|  . o o S     . o|
|   o .        .=o|
|    o .    . =  O|
|   . o o +..o Eo+|
|     .=.++= ....o|
+----[SHA256]-----+

[root@Masters ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub root@192.168.79.135
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
The authenticity of host '192.168.79.135 (192.168.79.135)' can't be established.
ECDSA key fingerprint is SHA256:+JLFbHH9xKqLcBg3hLQuk+C1wJhGyZotJ+jw9naCF0I.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys
root@192.168.79.135's password: 

Number of key(s) added: 1

Now try logging into the machine, with:   "ssh 'root@192.168.79.135'"
and check to make sure that only the key(s) you wanted were added.

配置Jenkins

Jenkins_运维_27

创建流水线任务

Jenkins_持续集成_28

使用脚本创建

第一阶段————项目克隆

Jenkins_持续集成_29


Jenkins_持续集成_30


Jenkins_运维_31


Jenkins_运维_32

[root@Masters ~]# cd /root/.jenkins/workspace/
[root@Masters workspace]# ls
K-DAY  K-DAY@2
[root@Masters workspace]# cd K-DAY
[root@Masters K-DAY]# ls
Dockerfile  LICENSE  README.md  db  pom.xml  src
[root@Masters K-DAY]#
第二阶段————生成站点

Jenkins_tomcat_33


Jenkins_jenkins_34


Jenkins_tomcat_35

第三阶段————scp的方式发送给Masters_A

Jenkins_持续集成_36


Jenkins_运维_37


Jenkins_运维_38

[root@Masters_A ~]# cd /usr/local/tomcat/webapps/
[root@Masters_A webapps]# ls
ROOT  examples      ly-simple-tomcat-0.0.1-SNAPSHOT      manager
docs  host-manager  ly-simple-tomcat-0.0.1-SNAPSHOT.war
[root@Masters_A webapps]#

访问测试

Jenkins_持续集成_39

发布流水线——文本参数方式

删除刚刚脚本构建传输的文件

[root@Masters_A webapps]# rm -rf ly-simple-tomcat-0.0.1-SNAPSHOT
[root@Masters_A webapps]# rm -rf ly-simple-tomcat-0.0.1-SNAPSHOT.war 
[root@Masters_A webapps]#

Jenkins_Jenkins_40


Jenkins_tomcat_41


Jenkins_jenkins_42


Jenkins_tomcat_43


Jenkins_运维_44

[root@Masters_A ~]# cd /usr/local/tomcat/webapps/
[root@Masters_A webapps]# ls
ROOT  examples      ly-simple-tomcat-0.0.1-SNAPSHOT      manager
docs  host-manager  ly-simple-tomcat-0.0.1-SNAPSHOT.war
[root@Masters_A webapps]#

Jenkins_持续集成_45