文档章节

Jenkins 解决Git插件不兼容问题的方案

IamOkay
 IamOkay
发布于 10/11 10:24
字数 781
阅读 425
收藏 6

简介

Jenkins 解决Git插件不兼容问题的方案,很多时候由于项目打包需求的插件版本不同,导致jenkins加载插件失败或者配置经常丢失。今天我们主要解决Git插件不兼容或者版本问题。当然方案很多种,这里我们使用的是不依赖Git插件的方式。

 

服务器环境

主机系统:CentOS 7 i5 4核心 4GB内存

服务器:Tomcat + Jenkins

项目:Android打包

 

解决原理

jenkins参数化构建过程是有顺序的,我们在build的项目之前选择Execute Shell来git clone 或者更新代码。以下整个配置都是关于【构建选项】模块的配置。

步骤1:验证用户名和密码

在linux bash中通过git clone 项目输入自己的用户名和密码,这一步可以让linux系统将用户名和密码保存在本地。

步骤2:使用脚本下载或者更新代码

更新代码的脚本如下:

#!/bin/bash

echo 'Start GitClient  for using git to update the project to '`pwd`

declare  GITURL='http://[你的项目地址]' #如https://gitee.com/cn_lyjuan/BaseUtil-Android.git
declare git_cmd='/usr/local/git/bin/git'

echo 'GitServer Address : ' ${GITURL}

echo 'git rev-parse --is-inside-work-tree'

declare needUpdate=false

$git_cmd  rev-parse --is-inside-work-tree >/dev/null 2>&1
if [ $? -eq 0 ]
then
     needUpdate=true
else
     needUpdate=false
fi

echo 'needUpdate is ' ${needUpdate}

if [ $needUpdate != true ]
then
	
	echo 'git clone the remote project from '${GITURL}
	rm -rf .git
	echo 'git init '`pwd`
	$git_cmd init `pwd`
	echo '------------start fetching--------------------'
	echo 'git --version'
	$git_cmd --version
	echo 'git -c core.askpass=true fetch --tags --progress' ${GITURL} '+refs/heads/*:refs/remotes/origin/*'
	$git_cmd -c core.askpass=true fetch --tags --progress ${GITURL} +refs/heads/*:refs/remotes/origin/*
	echo 'git config remote.origin.url' ${GITURL}
    $git_cmd config remote.origin.url $GITUR 
	echo 'git config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/*'
	$git_cmd config --add remote.origin.fetch +refs/heads/*:refs/remotes/origin/*
	echo 'git config remote.origin.url' ${GITURL}
	$git_cmd config remote.origin.url ${GITURL}

	echo '--------fetching upstream changes from '${GITURL} '----------'
	echo 'git -c core.askpass=true fetch --tags --progress' ${GITURL} '+refs/heads/*:refs/remotes/origin/*'
	$git_cmd -c core.askpass=true fetch --tags --progress ${GITURL} +refs/heads/*:refs/remotes/origin/*
	
	echo 'git rev-parse refs/remotes/origin/master^{commit}'
	
	declare commitId=$( $git_cmd rev-parse refs/remotes/origin/master^{commit}  )
	echo $commitId
	
	$git_cmd rev-parse refs/remotes/origin/origin/master^{commit} >/dev/null 2>&1
	if [ $? -eq 0 ]
	then
	    commitId=$( $git_cmd rev-parse refs/remotes/origin/origin/master^{commit} )
	fi
	echo '---------Checkout out Revision ' ${commitId}'--------'
	
	echo 'git config core.sparsecheckout'
	$git_cmd config core.sparsecheckout
	echo 'git checkout -f ' ${commitId}
	$git_cmd checkout -f ${commitId}
	
	echo 'unset varibiant'

	unset commitId
 
else

	
	echo 'git config remote.origin.url' ${GITURL}	
	$git_cmd config remote.origin.url $GITURL

	echo 'git --version'
	$git_cmd --version

	echo 'git fetch --tags --progress' ${GITURL} '+refs/heads/*:refs/remotes/origin/*'
	$git_cmd  fetch --tags --progress ${GITURL} +refs/heads/*:refs/remotes/origin/*

	echo 'git rev-parse origin/master^{commit}'
	declare commitId=$( $git_cmd rev-parse origin/master^{commit} )

	echo '-------fetching upstream of Revision is ' ${commitId} '-----'

	echo 'git config core.sparsecheckout'
	$git_cmd config core.sparsecheckout

	echo 'git checkout -f' ${commitId}
	$git_cmd checkout -f $commitId

	echo 'git rev-list '${commitId}
	$git_cmd rev-list $commitId -1

	unset commitId

fi

$git_cmd log -1

unset GITURL
unset git_cmd
        

echo 'finishly execute this script'

步骤3:配置打包参数

 

综上:我们可以解决Git插件不兼容的问题。本人对shell语法掌握不够熟练,以上脚本还有改造的潜能,如果有需要您可以自行改造。

 

 

 

© 著作权归作者所有

共有 人打赏支持
IamOkay
粉丝 190
博文 463
码字总数 376795
作品 0
海淀
程序员
私信 提问
加载中

评论(2)

IamOkay
IamOkay
不太明白,请指教
翠翠
翠翠
gradle 用 wrapper 比较好。
Jenkins与网站代码上线解决方案

1.1 前言 Jenkins是一个用Java编写的开源的持续集成工具。在与Oracle发生争执后,项目从Hudson项目独立。 Jenkins提供了软件开发的持续集成服务。它运行在Servlet容器中(例如Apache Tomcat...

侯召顺
2017/12/01
0
0
jenkins插件的安装与卸载

说明 Jenkins大部分的功能都是插件来实现的,所以必须知道jenkins插件的安装和卸载。 一、配置插件代理 jenkins在安装插件时候经常出现无法安装的情况,所以可以通过配置jenkins代理,来解决...

日久不生情
2017/11/17
0
0
spring-boot项目的docker集成化部署

spring-boot项目的docker集成化部署 [toc] 前言 据说流行的微服务和docker一起,更配哦!接下来,使用简单spring-boot项目演示docker的集成化部署的案例,在看过微笑的博客觉得不过瘾,自己动...

weir_will
10/06
0
0
大型互联网架构师必备团队协作专题

工程化专题 工欲善其事必先利其器,不管是小白,还是资深开发,都需要先选择好的工具。提升开发效率和团队协作效率,让自己有更多时间来思考 面向人群:具有1-5年工作经验的人群 Maven 生成可...

Java高级架构
2017/12/21
0
0
当 jenkins遇上Android Studio 3.0

概述 简介 jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件的持续集成变成可能。 关于Android Studio持续集...

wustor
2017/11/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

我的Linux系统九阴真经

我的Linux系统九阴真经 在今天,互联网的迅猛发展,科技技术也日新月异,各种编程技术也如雨后春笋一样,冒出尖来了。各种创业公司也百花齐放百家争鸣,特别是针对服务行业,新型互联网服务行...

linuxCool
48分钟前
12
0
Python程序员需要知道的30个技巧

1 直接交换两个数字位置 1x, y = 10, 202print(x, y)3x, y = y, x4print(x, y)5#1 (10, 20)6#2 (20, 10) 2 比较运算符的链接 1n = 102result = 1 < n < 203print(result)4# True5result = 1 ......

糖宝lsh
49分钟前
9
0
[LintCode] Linked List Cycle(带环链表)

描述 给定一个链表,判断它是否有环。 样例 给出 -21->10->4->5, tail connects to node index 1,返回 true。 这里解释下,题目的意思,在英文原题中,tail connects to node index 1 表示的...

honeymose
今天
10
0
Android :报错Your project path contains non-ASCII characters.

报错内容如下 Your project path contains non-ASCII characters. This will most likely cause the build to fail on Windows. Please move your project to a different directory. See ht......

lanyu96
今天
7
0
Nginx平滑添加模块

Nginx已经编译安装并运行了一段时间, 然后某一天, 发现需要用到某个模块但当初没有编译, 这个时候怎么办呢? 卸载重新安装肯定可以的, 如果Nginx版本没有变更的话, 则有一个相对平滑的方法来添...

老菜鸟0217
今天
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部