Jenkins环境搭建部署实现代码自动化发布

简介:

一、jenkins代码自动部署


1.配置免密钥通信

实现自动化部署首先要解决的是免密码传输,配置jenkins至测试服务器之间免密钥ssh登录

测试免密钥ssh登录

 

在测试服务器上编写一个测试脚本,检测是否可以执行成功,正式环境可以写一个自动化部署的脚本


2.jenkins新建部署代码项目

 
 

在构建这里选择执行shell命令 

点击立即构建 

控制台输出日志:成功

这样就实现了使用jenkins代码的自动化部署

实际情况中我们通常使用版本控制系统管理代码,svn 或者 git

 

二、gitlab利用webhook实现push代码后jenkins自动构建


jenkins服务器:192.168.239.134

gitlab服务器: 192.168.239.136

PS:如果gitlab与jenkins在同一台服务器,需要更改其中一个的端口,默认都是8080

之前部署了gitlab的代码托管平台和jenkins代码发布平台,通常是开发后的代码先推到Gitlab上管理,然后在Jenkins里

通过脚本构建代码发布。这种方式每次在发版的时候,需要人工去执行jenkins上的构建动作,有时显得过于繁琐

于是就想到了Gitlab的Webhook功能,通过Webhook的相关设置,可以实现代码Push后

自动去触发jenkins上的构建动作,这样就不需要人工干预去执行发版操作了

提前将jenkins本机的key添加到gitlab账户上

 

jenkins安装gitlab hook plugin插件

 

在auto_deploy项目工程里设置代码的git下载路径并关联构建的分支

查看jenkins生成回调地址,在任务构建触发器下获取回调URL

下面的URL那一行只有gitlab hook plugina插件下载成功后才能显示 

设置代码发布的推送脚本

 注意:这里使用192.168.239.136的test用户是与jenkins服务器已经配置了ssh免密钥登录

复制代码

#!/bin/bash
SOURCE_DIR=/root/.jenkins/workspace/${JOB_NAME}/DEST_DIR=/var/www/html/REMOTE_IP=192.168.239.136/usr/bin/rsync -e "ssh -p 22" -avpgolr --delete-before --exclude=.git $SOURCE_DIR test@$REMOTE_IP:$DEST_DIR

通过上面的git将代码下载到jenkins本机jobs里对应任务的workspace下,jenkins部署路径是/root/.jenkins/workspace/,脚本中${JOB_NAME}是jenkins的内置变量
也可以指定下载目录,加--exclude忽略哪些文件不需要进行rsync传输
#!/bin/bash
SOURCE_DIR=/data/git_tmpdata
再通过rsync将下载的代码分发到远程目标机器上

复制代码

 在192.168.239.136上创建/var/www/html/目录并授权test用户

 mkdir /var/www/html/ -p && chmod -R test.test /var/www/html/

 在gitlab上添加webhooks(注意这里是管理员用户才能添加)

 

Add Webhook添加完成后,在下方点击 test进行测试

 

如果返回Hook successfully executed.表示配置成功。
这样,下次push代码后,就会自动触发jenkins上相关的构建工程进行自动发布了!无需人工干预

 

 

在gitlab上push一个文件hello.py,然后测试下是否自动发布了

 

在jenkins上查看输出信息

在目标机器192.168.239.136的/var/www/html/目录下发现hello.py文件已经发布过来了

 


三、用jenkins 自动部署发布

   

#注意:jenkins路径会有差异,不用在意这个,同一个版本部署2次,发现了2个不同的目录结构,很诧异。


jenkins build玩war包的存放目录:/data/jenkins/workspace/simple/target 

自动发布的脚本存放路径:/data/jenkins/jobs/simple

wKioL1j1ezDSPALnAAEERyHSQvM960.png

脚本的内容:

脚本使用的是scp命令,当然也可以使用wget等。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
[root@localhost simple] # cat deploy_prod.sh 
#!/bin/bash
back_time=` date   + "%Y-%m-%d-%H-%M-%S" ` #备份的时间
all_ip=192.168.121.135
for_ip=` awk   'BEGIN{iplist="' $all_ip '";split(iplist,ip,",");for (s in ip) {print ip[s]}}' `   #awk数组转换
for   dest_ip  in   ${for_ip[*]}; do
     echo   $dest_ip
done
src= /data/jenkins/workspace/simple/target #下面就是重启scp的过程
war_name= "SimpleWeb-1.0.1-SNAPSHOT"
function   stop_tomcat () {
     Tomcat_id=` ssh   $dest_ip  lsof   -i:8080 |  awk   'NR==2' '{print $2}' `
if   [ ! Tomcat_id  ]; then
     echo   "tomcat id 不存在"
else
     ssh   $dest_ip  "/bin/kill -9 $Tomcat_id"
fi
}
function   start_tomcat () {
     ssh   $dest_ip  "cd /data/tomcat/bin && /bin/sh startup.sh"
}
if   [ -f $src/${war_name}.war ]; then
     stop_tomcat
     ssh   $dest_ip  "cd /data/tomcat/webapps && cp ${war_name}.war{,-${back_time}};cd /data/tomcat/webapps && /bin/rm -rf ${war_name}.war"
     ssh   $dest_ip  "cd /data/tomcat/webapps && /bin/rm -rf ${war_name}"
     scp   $src/${war_name}.war $dest_ip: /data/tomcat/webapps
     start_tomcat 
fi

数组转换防止出现多ip发布:

1
2
3
4
[root@localhost simple] # all_ip=192.168.121.131,192.168.121.135
[root@localhost simple] # awk 'BEGIN{iplist="'$all_ip'";split(iplist,ip,",");for (s in ip) {print ip[s]}}'
192.168.121.131
192.168.121.135

效果如下图:

wKioL1j1ewiAXsOzAADiGAk0FOo625.png


添加构建的执行脚本(注意不是在构建完执行的那块加):


wKiom1j1e3OipN3HAABO9IMztPU464.png


运行job,build完后会执行deploy脚本:

wKiom1j1e8jAg6R7AAAo4i456CU534.png

查看远程的tomcat是否发布完成:

wKiom1j1fA7yxpImAAEIt36ZKd4684.png


 当然一般也不会直接在一个工程下面直接加发布脚本,工程要是build不成功呢,或是这次build有问题

有人一直build的呢,会不会一直执行这个发布,同城都是再建一个视图,这个权限只有某些人有

build完后再执行这个deploy  job 做发布,加一个视图,再加一个自由构建风格的job

(pool很多的话可以加多个)做脚本运行发布的job。


首先copy一个视图:

wKiom1j1fFeBYfwBAAErMvhX3Wk500.png

配置脚本路径,只做脚本发布:

wKioL1j1fJGwbmdEAAFENxUNV8Y368.png

再次运行发布,会直接发布现在jenkins target目录下现存的war包,发布完的效果:

wKiom1j1fQODSZKYAAA9dQqZ4Sg275.png





本文转自 2012hjtwyf 51CTO博客,原文链接:http://blog.51cto.com/hujiangtao/1930536,如需转载请自行联系原作者

相关文章
|
8天前
|
Serverless 决策智能 UED
构建全天候自动化智能导购助手:从部署者的视角审视Multi-Agent架构解决方案
在构建基于多代理系统(Multi-Agent System, MAS)的智能导购助手过程中,作为部署者,我体验到了从初步接触到深入理解再到实际应用的一系列步骤。整个部署过程得到了充分的引导和支持,文档详尽全面,使得部署顺利完成,未遇到明显的报错或异常情况。尽管初次尝试时对某些复杂配置环节需反复确认,但整体流程顺畅。
|
23天前
|
运维 jenkins Java
Jenkins 自动化局域网管控软件构建与部署流程
在企业局域网管理中,Jenkins 作为自动化工具,通过配置源码管理、构建及部署步骤,实现了高效、稳定的软件开发与部署流程,显著提升局域网管控软件的开发与运维效率。
39 5
|
1月前
|
监控 安全 测试技术
在实施自动化和持续集成的过程中,如何确保代码的安全性和合规性
在自动化和持续集成中,确保代码安全与合规至关重要。措施包括集成自动化安全工具、执行自动化合规检查、进行代码质量与安全检测、评估开源代码安全、实施基础设施即代码的安全标准、采用多层防御策略、加强安全教育与文化建设、使用合规性检测工具及许可证合规分析等,共同提升代码安全性与合规水平。
|
1月前
|
监控 安全 测试技术
在实施自动化和持续集成的过程中,如何确保代码的安全性和合规性?
在实施自动化和持续集成的过程中,如何确保代码的安全性和合规性?
|
2月前
|
运维 监控 jenkins
运维自动化实战:利用Jenkins构建高效CI/CD流程
【10月更文挑战第18天】运维自动化实战:利用Jenkins构建高效CI/CD流程
|
2月前
|
运维 监控 jenkins
运维自动化实践:利用Jenkins实现高效CI/CD流程
【10月更文挑战第18天】运维自动化实践:利用Jenkins实现高效CI/CD流程
|
2月前
|
运维 持续交付 开发工具
基础设施即代码(IaC):自动化基础设施管理的未来
基础设施即代码(IaC):自动化基础设施管理的未来
68 0
|
1月前
|
jenkins Devops Java
DevOps实践:Jenkins在持续集成与持续部署中的价值
【10月更文挑战第27天】在快速发展的软件开发领域,DevOps实践日益重要。Jenkins作为一款流行的开源自动化服务器,在持续集成(CI)和持续部署(CD)中扮演关键角色。本文通过案例分析,探讨Jenkins在Java项目中的应用,展示其自动化构建、测试和部署的能力,提高开发效率和软件质量。
66 2
|
4月前
|
jenkins 持续交付 开发者
自动化部署:使用Jenkins和Docker实现持续集成与交付
【8月更文挑战第31天】本文旨在为读者揭示如何通过Jenkins和Docker实现自动化部署,从而加速软件开发流程。我们将从基础概念讲起,逐步深入到实际操作,确保即使是初学者也能跟上步伐。文章将提供详细的步骤说明和代码示例,帮助读者理解并应用这些工具来优化他们的工作流程。
|
16天前
|
监控 jenkins Linux
从 Jenkins 持续集成出发:探究如何监控员工电脑屏幕
Jenkins 在企业信息化管理中用于自动化构建、测试和部署,提高开发效率。本文讨论了其重要性,并从技术角度探讨了屏幕监控的可能性,但明确反对非法监控,强调应合法合规地管理企业和尊重员工隐私。
61 12