最近寫了一篇部落格是關於 使用Jenkins來構建SVN+Maven專案 ,這裡使用的的程式碼版本工具是SVN
,但是事實上也有很多公司使用GIT
來進行程式碼管理,那麼我們如何使用Jenkins
去自動釋出GIT
+Maven
專案呢?
Jenkins是一個開源的、可延伸的持續整合、交付、部署的基於web
介面的平臺。允許持續整合和持續交付專案,無論用的是什麼平臺,可以處理任何型別的構建或持續整合。
通常我們使用Jenkins
主要實現以下功能:
其實很多系統都會自帶git
工具,但是由於自帶的git
版本太低,無法滿足jenkins
對git
工具版本的需求,所以建議升級git
後,再進行jenkins
的安裝和設定。
第一步:安裝所需的依賴
yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel
yum install gcc perl-ExtUtils-MakeMaker
yum install perl-ExtUtils-MakeMaker package
第二步:解除安裝原有GIT
yum remove -y git
git --version
第三步:安裝新的GIT
cd /usr/local/src/
wget https://www.kernel.org/pub/software/scm/git/git-2.15.1.tar.xz
tar -vxf git-2.15.1.tar.xz
cd git-2.15.1
make prefix=/usr/local/git all
make prefix=/usr/local/git install
echo "export PATH=$PATH:/usr/local/git/bin" >> /etc/profile
source /etc/profile
git --version
第四步:建立GIT連結
ln -s /usr/local/git/bin/git-upload-pack /usr/bin/git-upload-pack
ln -s /usr/local/git/bin/git-receive-pack /usr/bin/git-receive-pack
第一步:jenkins伺服器生成公鑰和金鑰
/root/.ssh/id_rsa.pub
:公鑰,通常用於加密對談金鑰。/root/.ssh/id_rsa
:金鑰,用於驗證數位簽章。/root/.ssh/authorized_keys
:存放其他伺服器的公鑰。執行下面的命令後將自動生成對應檔案
ssh-keygen -t rsa
第二步:將jenkins生成的公鑰id_rsa.pub
加入到git伺服器authorized_keys
檔案中
chattr -ia authorized_keys
chmod 777 authorized_keys
vim authorized_keys
第三步:獲取金鑰id_rsa
的內容
cat /root/.ssh/id_rsa
第一步:下載war安裝包
官方下載地址:https://www.jenkins.io/download/
第二步:安裝並設定Jenkins
nohup java -jar jenkins.war &
jenkins預設的路徑:IP:8080
,進入管理介面後根據提示進行設定
Jenkins
外掛第三步:根據需要安裝Jenkins外掛
在jenkins——Manage Jenkins——外掛管理中安裝以下外掛:
ssh
方式連線遠端伺服器,從而實現程式碼遠端推播。第四步:設定本地工具
在jenkins——Manage Jenkins——Global Tool Configuration中設定Maven
、JDK
和GIT
:
Maven
來構建專案JDK
為專案提供了執行環境GIT
為程式碼的版本控制倉庫。Maven
設定
JDK
的設定
GIT
的設定
第五步:設定系統設定
在jenkins——Manage Jenkins——System Configuration中設定遠端伺服器,這個伺服器即為專案的執行容器。
第六步:設定GIT金鑰
在jenkins-憑據-系統-全域性憑據 中設定git
金鑰
第七步:建立一個新任務,設定原始碼管理、構建和構建後操作
原始碼管理
構建
構建後操作
run.sh:指令碼用於啟動spring-dubbo-producer.jar
APP_NAME=spring-dubbo-producer.jar
path=`pwd`
#使用說明,用來提示輸入引數
usage() {
echo "Usage: sh 執行指令碼.sh [start|stop|restart|status]"
exit 1
}
#檢查程式是否在執行
is_exist(){
pid=`ps -ef|grep $APP_NAME|grep -v grep|awk '{print $2}' `
#如果不存在返回1,存在返回0
if [ -z "${pid}" ]; then
return 1
else
return 0
fi
}
#啟動方法
start(){
is_exist
if [ $? -eq "0" ]; then
echo "${APP_NAME} is already running. pid=${pid} ."
else
source /etc/profile
nohup java -jar $APP_NAME > $path/logs.txt 2>&1 &
fi
}
#停止方法
stop(){
is_exist
if [ $? -eq "0" ]; then
kill -9 $pid
else
echo "${APP_NAME} is not running"
fi
}
#輸出執行狀態
status(){
is_exist
if [ $? -eq "0" ]; then
echo "${APP_NAME} is running. Pid is ${pid}"
else
echo "${APP_NAME} is NOT running."
fi
}
#重新啟動
restart(){
stop
start
}
#根據輸入引數,選擇執行對應方法,不輸入則執行使用說明
case "$1" in
"start")
start
;;
"stop")
stop
;;
"status")
status
;;
"restart")
restart
;;
*)
usage
;;
esac
第七步:構建專案,進行驗證
構建專案
驗證
存取自己的專案的介面進行驗證,我這裡以knife4j
為例:ip:8080/doc.html