jenkins发布控制版本号和同步 您所在的位置:网站首页 巨人同步脚本 jenkins发布控制版本号和同步

jenkins发布控制版本号和同步

#jenkins发布控制版本号和同步| 来源: 网络整理| 查看: 265

二、实现和测试效果

  先给大家看看效果:

1、测试前(发布jenkins前):

(1).env文件显示版本号为:v1.0.1 (如上图)

(2)jenkins发布前显示:

 2、测试后(发布jenkins后):

(1).env文件版本号最后一个数字递增1

 (2)下一次jenkins发布前显示:

  对于这个需求,在实现修改文件版本号和同步回gitlab外,我还做了jenkins控制台的当前版本号和上一个发布版本号的显示(如上图),这个参考了小强的利用jenkins动态参数插件的文档:Dynamic Parameter Plug-in(groovy脚本),当然我加了些优化(站在巨人的肩膀上,哈哈哈~~),就是有个new_version,跟我当前需要修改成的版本号对应上了,方便测试人员看。

实现思路:

  思路不难想出来,每次jenkins发布都会在工作区间拉下该项目的代码,利用jenkins运行用户修改文件,再推送代码即可。

  我这里环境稍有不同,运行jenkins的用户就是jenkins,没有登录权限(/etc/passwd 显示为 /bin/false),如果不给登录权限,无法修改该 .env 文件的版本号,且进行下一步的maven编译。

  所以第一件事,确保jenkins用户有登录权限,参考:   https://blog.csdn.net/weixin_37417954/article/details/83589632

  上面可以理解为预处理。。。 以自由风格的软件项目做测试。

1、准备一个版本号记录文件,记录格式:

项目关键字 版本号 发布时间

2、jenkins控制台的参数化过程添加动态参数(Dynamic Parameter)

(1)old_version

def sout = new StringBuffer(), serr = new StringBuffer() def command = "sh /var/lib/jenkins/scripts/get_version/admin/get_oldver.sh admin" def proc = command.execute() proc.consumeProcessOutput(sout, serr) proc.waitForOrKill(10) return sout.tokenize() View Code

(2)new_version

   跟old_version代码类似,只是def comand 这里运行另一个脚本,用于获取下一个发布版本号:/var/lib/jenkins/scripts/get_version/get_newver.sh admin

  代码有点像更新版本号的脚本。从版本号记录文件最后一行读起,对版本号最后一个数字进行递增,然后echo出来让控制台能捕捉到这个数值。

 3、jenkins控制台的构建,执行shell配置

这里主要实现修改.env版本号及同步更新该文件到gitlab上

##### 1、jenkins工作区间版本号替换再编译 #### 1.1、写入版本号信息到版本号记录文件(从上面动态参数获取) old_ver=`echo $old_version | tr -d "[" | tr -d "]"` new_ver=`echo $new_version | tr -d "[" | tr -d "]"` DATE=`date +%Y%m%d_%H:%M:%S`

  ## 是生产分支才记录  if [ $branch == "生产分支" ]; then

     echo admin ${new_ver} $DATE >> /var/lib/jenkins/scripts/xxx/get_version/xxx/xxx_version.txt

fi #### 1.2、文件版本号替换 sed -i "s/${old_ver}/${new_ver}/" .env ##### 2、更新文件版本号,上传到gitlab ssh 某用户@{jenkins发布机器ip} -p 55100 "sh -x /home/{某用户}/scripts/xxx/update_version/update_admin.sh $branch"

##### npm编辑

npm installnpm run build:test

最后贴下更新版本号的脚本:

#!/bin/bash ####################################################### # $Name: update_admin.sh # $Version: v1.0 # $Function: 更新xxx项目-前端版本号 # git目录: /home/{某用户}/app/update_version/ ####################################################### ## 1、拉取的分支 Pull_Branch=$1 ## 2、拉取的目录,项目名 Git_Dir=/home/{某用户}/app/update_version/{某项目} Admin_Dir=${Git_Dir}/{项目二级目录} cd ${Git_Dir} ## 不存在就克隆仓库 if [ ! -d ${Admin_Dir} ]; then git clone -b ${Pull_Branch} ssh://{git地址}/{某项目}.git ## 存在就判断是否是发布分支 ## 更新最新代码 else cd ${Admin_Dir} br=`git branch |grep "*"` localbr=`echo ${br/* /}` # 不等于发布的分支,则切换分支 if [ "$localbr" != "$Pull_Branch" ]; then git checkout $Pull_Branch fi # 更新最新代码 git pull origin ${Pull_Branch} fi ## 3、更新版本号 cd ${Admin_Dir} src_ver=`cat .env |awk -F'=' '{print $2}' | tr -d "'"` last_num=`echo $src_ver | awk -F'.' '{print $NF}'` this_num=$(($last_num+1)) begin_num=`expr substr "$src_ver" 1 5` dst_ver=$begin_num$this_num echo $dst_ver sed -i "s/${src_ver}/${dst_ver}/" .env ## 4、上传代码 git add .env git commit -m "update .env version" git push origin ${Pull_Branch}:${Pull_Branch} View Code

 

 三、一些问题

1、jenkins用户无法在工作区间上进行代码更新

  大家可以留意到我上面第3步执行shell配置那里,特意用ssh调用某个用户的某个脚本进行代码更新。本来我也不想这弄的,但发现直接在jenkins的工作区间进行push操作会报错,所以只能额外利用另一个目录去存放拉取的git项目,以该用户推送代码达到更新版本号文件的目的。

  而为了不需要明文显示密码,要在jenkins用户配置ssh密钥放到该用户下,达到免密钥去调用该用户的脚本。

  其实可以的话,最好是能在jenkins工作区间同步回去,不然存多一份代码文件,有点浪费硬盘空间,这里我还没细致研究出来是否可以这么做。

2、发布分支和版本号没对应上

  更新版本号的脚本可以留意到我进行了分支的判断,因为有可能上一次发布分支和当前不是同一个,意味着动态参数获取版本号,如果换了分支号就会失效,上一个版本号和将要发布的版本号会显示为空。

所以,应该发布不同分支号,读取对应相应分支的版本记录文件,或者这个文件多记录一个分支号的字段,这里还没测试。

  所以目前做下来是有bug的,如果上一次发布test1,这次发布test,再下次发布test1,控制台显示的版本号会是错的!!!要加个是发布分支才写入文件的判断。



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有