需求:项目是java maven项目,每次修改后上线流程为 :
修改代码-->上传到git服务器-->从git上拉取新代码-->执行mvn clean package将项目打包成war包--->复制到tomcat的webapps下,重启tomcat服务,项目完成更新。 以上步骤均为人工完成。
如何利用jenkins实现持续化集成?
jenkins中安装git 和 maven相关插件后 可实现:
修改代码-->上传到git服务器-->jenkins构建-->项目更新。只有将代码上传git为人工,其余均为自动部署。
中间jenkins做了什么呢?替代了上面所说的人为的过程:
jenkins从git上拉代码到自己的workspce下,mvn插件打包,生成war包,通过构建后写shell实现tomcat那些步骤。
需要的server
1.jenkins服务器:192.168.1.252 (安装jdk,maven)
2.git服务器:192.168.1.102 (创建一个git仓库,地址:)
3.web服务器:192.168.1.101 (后面将其变成jenkins slave节点,让任务在自己机器上执行,节省jenkins 压力)
安装前准备
1.jenkins服务器上要安装maven和jdk,安装过程见(《配置maven项目》)
2.git仓库(1.102)创建:
创建git专用用户(以后链接远端仓库就用这个账户)
yum install git
useradd git
passwd git
su - git
[git@server-3 ~]$ mkdir -p repo_git/pans.git
[git@server-3 ~]$ cd repo_git/pans.git
[git@server-3 pans.git]$ git init --bare
[git@server-3 pans.git]$ ls
branches config description HEAD hooks info objects refs
仓库地址为:git@192.168.1.102:/home/git/repo_git/pans.git
这里仓库就创建完成了,git init --bare创建裸仓库,只保存git历史提交的版本信息,而不允许用户在上面进行各种git操作。
3.web服务器(1.101)克隆git项目到本地
yum install git
随便进入一个文件夹
git clone git@192.168.1.102:/home/git/repo_git/pans.git
项目拉下来是个空仓库,把项目放进去 ,我的项目名是java_web
[root@server2 pans]# pwd
/root/bb/pans
[root@server2 pans]# ls
java_web java_web.tar.gz
然后将代码提交到仓库里。
git add ;git commit -m "first push";git push
Jenkins配置
1.全局配置
系统管理-->全局配置-->配置jdk和maven的路径
image.png image.png
系统管理里一般都是配合ssh插件配置秘钥,或者用到邮件等功能再去配置。
我这里在机器上之间都做好了ssh-keygen免秘钥登陆,就不在jenkins里配了。
创建一个Maven Job
左侧导航栏新建任务--->创建一个maven项目(如果没有,需要安装maven插件[Maven Integration plugin])
JOB配置截图:
image.pngimage.png
这里由于git用的不是github所以没有勾选github hook选项,如果用的github作为代码托管一定要配合webhook和这个构建选项的触发器,可实现自动构建。
image.png
image.png
脚本部分是构建成war包后执行的操作,功能是将生成的war 复制到tomcat web目录下,重启服务。
利用Jenkins Slave节点
当我们的项目打包以及job整个过程资源占用很大的时候,我们的jenkins就会占用大量io以及负载。
我们可以分节点来执行这些job。如:我在jenkins服务器点击构建,而执行的时候是在添加的slave节点上去完成,这样不会占用jenkins过多io 减轻负载。
如何设置jenkins salve
image.png左侧导航栏新建节点 ;输入节点名字
image.png
image.png
保存退出。
启动节点,可看到
image.png
salve设置好了,那么构建的时候如何将任务分配给它?
在job设置中指定
image.png
保存退出。
构建一次试试:(过程主要就是Jenkins拉取git上的代码到自己工作目录,在将项目打成war包,放到tomcat,上线)
image.pngimage.png
image.png image.png
网友评论