jenkins运行日志时间与linux,持续集成之Jenkins结合脚本实现代码自动化部署及一键回滚至上一版本...
一:本文通過(guò)jenkins調(diào)用shell腳本的的方式完成從Git服務(wù)器獲取代碼、打包、部署到web服務(wù)器、將web服務(wù)器從負(fù)載均衡器刪除、解壓、復(fù)制配置文件、創(chuàng)建軟連接、測(cè)試每一臺(tái)web服務(wù)器、將web服務(wù)器添加至負(fù)載均衡、回滾到任意指定版本、一鍵回滾到上一版本等功能,腳本放在www用戶家目錄并使用www用戶身份執(zhí)行,每個(gè)web服務(wù)器也都使用www用戶運(yùn)行web服務(wù),且UID相同web目錄和權(quán)限都一致,更嚴(yán)格的標(biāo)準(zhǔn)化可以帶來(lái)更安全的生產(chǎn)環(huán)境和更高的效率:
1.1:在jenkins項(xiàng)目配置中調(diào)用shell腳本與環(huán)境準(zhǔn)備:
1.1.1:#jenkins-項(xiàng)目-配置:
1.1.2:www用戶家目錄中的腳本內(nèi)容:
$ cat code_deploy.sh
#!/bin/bash
#Dir List 部署節(jié)點(diǎn)(即部署節(jié)點(diǎn)需要做的操作)
# mkdir -p /deploy/code/web-demo
# mkdir -p /deploy/config/web-demo/base
# mkdir -p /deploy/config/web-demo/other
# mkdir /deploy/tmp
# mkdir /deploy/tar
# chown -R www.www /deploy
# chown -R www.www /webroot
# chown -R www.www /opt/webroot/
# chown -R www.www /webroot
# 需要在客戶端節(jié)點(diǎn)做的操作
# mkdir /opt/webroot
# mkdir /webroot
# chown -R www.www /webroot
# chown -R www.www /opt/webroot/
# chown -R www.www /webroot
# [www@ ~]$ touch /webroot/web-dem
# Node List 服務(wù)器節(jié)點(diǎn)
PRE_LIST="192.168.3.12"? ? ? ? # 預(yù)生產(chǎn)節(jié)點(diǎn)
GROUP1_LIST="192.168.3.12 192.168.3.13"
GROUP2_LIST="192.168.3.13"
ROLLBACK_LIST="192.168.3.12 192.168.3.13"
# 日志日期和時(shí)間變量
LOG_DATE='date "+%Y-%m-%d"' # 如果執(zhí)行的話后面執(zhí)行的時(shí)間,此時(shí)間是不固定的,這是記錄日志使用的時(shí)間
LOG_TIME='date "+%H-%M-%S"'
# 代碼打包時(shí)間變量
CDATE=$(date "+%Y-%m-%d") # 腳本一旦執(zhí)行就會(huì)取一個(gè)固定時(shí)間賦值給變量,此時(shí)間是固定的
CTIME=$(date +"%H-%M-%S")
# shell env 腳本位置等變量
SHELL_NAME="deploy.sh"? ? # 腳本名稱
SHELL_DIR="/home/www/"? # 腳本路徑
SHELL_LOG="${SHELL_DIR}/${SHELL_NAME}.log" # 腳本執(zhí)行日志文件路徑
# code env 代碼變量
PRO_NAME="web-demo"? ? # 項(xiàng)目名稱的函數(shù)
CODE_DIR="/deploy/code/web-demo"? ? # 從版本管理系統(tǒng)更新的代碼目錄
CONFIG_DIR="/deploy/config/web-demo"? ? # 保存不同項(xiàng)目的配置文件,一個(gè)目錄里面就是一個(gè)項(xiàng)目的一個(gè)配置文件或多個(gè)配置文件
TMP_DIR="/deploy/tmp"? ? ? ? ? ? # 臨時(shí)目錄
TAR_DIR="/deploy/tar"? ? ? ? ? ? # 打包目錄
LOCK_FILE="/tmp/deploy.lock" # 鎖文件路徑
usage(){ # 使用幫助函數(shù)
echo $"Usage: $0 [ deploy | rollback [ list | emergency | version ]"
}
writelog(){ # 寫(xiě)入日志的函數(shù)
LOGINFO=$1 # 將參數(shù)作為日志輸入
echo "${CDATE} ${CTIME} : ${SEHLL_NAME} : ${LOGINFO}" >> ${SHELL_LOG}
}
# 鎖函數(shù)
shell_lock(){
touch ${LOCK_FILE}
}
# 解鎖函數(shù)
shell_unlock(){
rm -f ${LOCK_FILE}
}
# 獲取代碼的函數(shù)
code_get(){
echo "code_get"
writelog code_get
cd $CODE_DIR && git pull # 進(jìn)入到代碼目錄更新代碼,此處必須免密碼更新,此目錄僅用于代碼更新不能放其他任何文件
cp -rf ${CODE_DIR} ${TMP_DIR}/ # 臨時(shí)保存代碼并重命名,包名為時(shí)間+版本號(hào),準(zhǔn)備復(fù)制到web服務(wù)器
API_VERL=$(git show | grep commit | cut -d ' ' -f2)
API_VER=$(echo ${API_VERL:0:8})? ? ? ? # 版本號(hào)
}
code_build(){ # 代碼編譯函數(shù)
echo code_build
}
code_config(){ # 配置文件函數(shù)
writelog "code_config"
/bin/cp -rf ${CONFIG_DIR}/base/* ${TMP_DIR}/"${PRO_NAME}" # 將配置文件放在本機(jī)保存配置文件的臨時(shí)目錄,用于暫時(shí)保存代碼項(xiàng)目
PKG_NAME="${PRO_NAME}"_"$API_VER"_"${CDATE}-${CTIME}"? ? # 定義代碼目錄名稱
cd ${TMP_DIR} && mv ${PRO_NAME} ${PKG_NAME}? ? # 重命名代碼文件為web-demo_123-20170629-11-19-10格式
}
code_tar(){? ? # 對(duì)代碼打包函數(shù)
writelog code_tar
cd ${TMP_DIR} && tar czf ${PKG_NAME}.tar.gz ${PKG_NAME} --exclude=".git" # 將目錄打包成壓縮文件,便于網(wǎng)絡(luò)傳輸
writelog "${PKG_NAME}.tar.gz packaged success"? ? # 記錄打包成功的日志
}
code_scp(){ # 代碼壓縮包scp到客戶端的函數(shù)
writelog? "code_scp"
for node in $PRE_LIST;do # 循環(huán)服務(wù)器節(jié)點(diǎn)列表
scp ${TMP_DIR}/${PKG_NAME}.tar.gz $node:/opt/webroot/ # 將壓縮后的代碼包復(fù)制到web服務(wù)器的/opt/webroot
done
for node in $GROUP1_LIST;do # 循環(huán)服務(wù)器節(jié)點(diǎn)列表
scp ${TMP_DIR}/${PKG_NAME}.tar.gz $node:/opt/webroot/ # 將壓縮后的代碼包復(fù)制到web服務(wù)器的/opt/webroot
done
}
cluster_node_add(){ #將web服務(wù)器添加至前端負(fù)載
echo cluster_node_add
}
cluster_node_remove(){ # 將web服務(wù)器從集群移除函數(shù)(正在部署的時(shí)候應(yīng)該不處理業(yè)務(wù))
writelog "cluster_node_remove"
}
url_test(){
URL=$1
curl -s --head $URL |grep '200 OK'
if [ $? -ne 0 ];then
shell_unlock;
writelog "test error" && exit;
fi
}
pre_deploy(){ # 代碼解壓部署函數(shù),預(yù)生產(chǎn)節(jié)點(diǎn)
writelog "pre_deploy"
for node in ${PRE_LIST};do # 循環(huán)預(yù)生產(chǎn)服務(wù)器節(jié)點(diǎn)列表
cluster_node_remove? ${node} # 部署之前將節(jié)點(diǎn)從前端負(fù)載刪除
echo? "pre_deploy, cluster_node_remove ${node}"
ssh ${node} "cd /opt/webroot && tar zxf ${PKG_NAME}.tar.gz" #分別到web服務(wù)器執(zhí)行壓縮包解壓命令
ssh ${node} "rm -f /webroot/web-demo && ln -s /opt/webroot/${PKG_NAME} /webroot/web-demo" # 整個(gè)自動(dòng)化的核心,創(chuàng)建軟連接
done
}
pre_test(){ # 預(yù)生產(chǎn)主機(jī)測(cè)試函數(shù)
for node in ${PRE_LIST};do # 循環(huán)預(yù)生產(chǎn)主機(jī)列表
curl -s --head http://${node}:9999/index.html | grep "200 OK" # 測(cè)試web界面訪問(wèn)
if [ $? -eq 0 ];then? # 如果訪問(wèn)成功
writelog " ${node} Web Test OK!" # 記錄日志
echo " ${node} Web Test OK!"
cluster_node_add ${node} # 測(cè)試成功之后調(diào)用添加函數(shù)把服務(wù)器添加至節(jié)點(diǎn),
writelog "pre,${node} add to cluster OK!" # 記錄添加服務(wù)器到集群的日志
else # 如果訪問(wèn)失敗
writelog "${node} test no OK" # 記錄日志
echo "${node} test not OK"
shell_unlock # 調(diào)用刪除鎖文件函數(shù)
break # 結(jié)束部署
fi
done
}
group1_deploy(){ # 代碼解壓部署函數(shù)
writelog "group1_code_deploy"
for node in ${GROUP1_LIST};do # 循環(huán)生產(chǎn)服務(wù)器節(jié)點(diǎn)列表
cluster_node_remove $node
echo "group1, cluster_node_remove $node"
ssh ${node} "cd /opt/webroot && tar zxf ${PKG_NAME}.tar.gz" # 分別到各web服務(wù)器節(jié)點(diǎn)執(zhí)行壓縮包解壓命令
ssh ${node} "rm -f /webroot/web-demo && ln -s /opt/webroot/${PKG_NAME} /webroot/web-demo" # 整個(gè)自動(dòng)化的核心,創(chuàng)建軟連接
done
scp ${CONFIG_DIR}/other/192.168.3.13.server.xml 192.168.3.13:/webroot/web-demo/server.xml? # 將差異項(xiàng)目的配置文件scp到此web服務(wù)器并以項(xiàng)目結(jié)尾
}
group1_test(){ # 生產(chǎn)主機(jī)測(cè)試函數(shù)
for node in ${PRE_LIST};do # 循環(huán)生產(chǎn)主機(jī)列表
curl -s --head http://${node}:9999/index.html | grep "200 OK" #測(cè)試web界面訪問(wèn)
if [ $? -eq 0 ];then? #如果訪問(wèn)成功
writelog " ${node} Web Test OK!" #記錄日志
echo "group1_test,${node} Web Test OK!"
cluster_node_add
writelog " ${node} add to cluster OK!" #記錄將服務(wù)器 添加至集群的日志
else #如果訪問(wèn)失敗
writelog "${node} test no OK" #記錄日志
echo "${node} test no OK"
shell_unlock # 調(diào)用刪除鎖文件函數(shù)
break # 結(jié)束部署
fi
done
}
emergency_code_get(){ #獲取代碼的函數(shù)
writelog "code_get"
cd ${CODE_DIR} && git reset --hard HEAD^? #進(jìn)入到代碼目錄更新代碼,此處必須免密碼更新,此目錄僅用于代碼更新不能放其他任何文件
/bin/cp -rf ${CODE_DIR} ${TMP_DIR}/ #臨時(shí)保存代碼并重命名,包名為時(shí)間+版本號(hào),準(zhǔn)備復(fù)制到web服務(wù)器
API_VERL=$(git show | grep commit | cut -d ' ' -f2)
API_VER=$(echo ${API_VERL:0:8}) #取八位
}
emergency(){? #緊急回退到上一個(gè)版本函數(shù)
emergency_code_get #執(zhí)行將代碼回退到上一個(gè)版本函數(shù)
code_build; #如果要編譯執(zhí)行編譯函數(shù)
code_config; #cp配置文件
code_tar; #打包
code_scp; #scp到服務(wù)器
cluster_node_remove;
pre_deploy; #預(yù)生產(chǎn)環(huán)境部署
pre_test; #預(yù)生產(chǎn)環(huán)境測(cè)試
group1_deploy; #生產(chǎn)環(huán)境部署
group1_test; #生產(chǎn)環(huán)境測(cè)試
code_config; #cp差異文件
#code_test; #代碼測(cè)試
shell_unlock #執(zhí)行完成后刪除鎖文件
}
rollback_fun(){
for node in $ROLLBACK_LIST;do # 循環(huán)服務(wù)器節(jié)點(diǎn)列表
# 注意一定要加"號(hào),否則無(wú)法在遠(yuǎn)程執(zhí)行命令
ssh $node "rm -f /webroot/web-demo && ln -s /opt/webroot/$1 /webroot/web-demo" # 立即回滾到指定的版本,$1即指定的版本參數(shù)
echo "${node} rollback success!"
done
}
rollback(){ # 代碼回滾主函數(shù)
if [ -z $1 ];then
shell_unlock # 刪除鎖文件
echo "Please input rollback version" && exit 3;
fi
case $1 in # 把第二個(gè)參數(shù)做當(dāng)自己的第一個(gè)參數(shù)
list)
ls -l /opt/webroot/*.tar.gz
;;
*)
rollback_fun $1
esac
}
main(){
if [ -f $LOCK_FILE ] ;then # 先判斷鎖文件在不在,如果有鎖文件直接退出
echo "Deploy is running" && exit 10
fi
DEPLOY_METHOD=$1 # 避免出錯(cuò)誤將腳本的第一個(gè)參數(shù)作為變量
ROLLBACK_VER=$2
case $DEPLOY_METHOD in
deploy) # 如果第一個(gè)參數(shù)是deploy就執(zhí)行以下操作
shell_lock; # 執(zhí)行部署之前創(chuàng)建鎖。如果同時(shí)有其他人執(zhí)行則提示鎖文件存在
code_get; # 獲取代碼
code_build; # 如果要編譯執(zhí)行編譯函數(shù)
code_config; # cp配置文件
code_tar;? ? # 打包
code_scp;? ? # scp到服務(wù)器
pre_deploy;? # 預(yù)生產(chǎn)環(huán)境部署
pre_test;? ? # 預(yù)生產(chǎn)環(huán)境測(cè)試
group1_deploy; # 生產(chǎn)環(huán)境部署
group1_test;? # 生產(chǎn)環(huán)境測(cè)試
shell_unlock; # 執(zhí)行完成后刪除鎖文件
;;
rollback) # 如果第一個(gè)參數(shù)是rollback就執(zhí)行以下操作
shell_lock; # 回滾之前也是先創(chuàng)建鎖文件
rollback $ROLLBACK_VER;
shell_unlock; # 執(zhí)行完成刪除鎖文件
;;
emergency)
emergency; #緊急回退就不需要參數(shù)了,但是在執(zhí)行的時(shí)候要確認(rèn)一下是否要緊急回退,避免輸入錯(cuò)誤
;;
*)
usage;
esac
}
main $1 $2
1.1.4:修改當(dāng)前web頁(yè)面:
[www@master ~]$ cd web-demo
[www@master web-demo]$ echo "
jenkins deploy test" > index.html
[www@master web-demo]$ git add index.html
[www@master web-demo]$ git commit -m "jenkins deploy test"
[master 9a43cf5] jenkins deploy test
1 file changed, 1 insertion(+), 1 deletion(-)
[www@master web-demo]$ git push -u origin master
Counting objects: 5, done.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 276 bytes | 0 bytes/s, done.
Total 3 (delta 1), reused 0 (delta 0)
To git@192.168.3.198:web/web-demo.git
beb37cb..9a43cf5 master -> master
Branch master set up to track remote branch master from origin.
1.4:回滾到任意版本:
1.4.1:在哪看回滾到的版本?:
$ ll /deploy/tmp/ #部署服務(wù)器,web服務(wù)器在nginx定義的目錄查看版本
1.4.3:在jenkins執(zhí)行回滾:
[root@slave01 ~]# ll /opt/webroot/
total 20672
drwxr-xr-x 5 www www 4096 Jun 26 11:36 web-demo_123_2017-06-26-11-36-44
-rw-rw-r-- 1 www www 1243347 Jun 28 22:03 web-demo_123_2017-06-26-11-36-44.tar.gz
drwxr-xr-x 5 www www 4096 Jun 26 11:39 web-demo_123_2017-06-26-11-39-02
-rw-rw-r-- 1 www www 1243347 Jun 28 22:06 web-demo_123_2017-06-26-11-39-02.tar.gz
drwxr-xr-x 5 www www 4096 Jun 26 12:04 web-demo_123_2017-06-26-12-04-19
-rw-rw-r-- 1 www www 1243351 Jun 28 22:31 web-demo_123_2017-06-26-12-04-19.tar.gz
drwxr-xr-x 5 www www 4096 Jun 26 12:16 web-demo_123_2017-06-26-12-16-49
-rw-rw-r-- 1 www www 1243347 Jun 28 22:43 web-demo_123_2017-06-26-12-16-49.tar.gz
drwxr-xr-x 5 www www 4096 Jun 26 12:18 web-demo_123_2017-06-26-12-18-09
-rw-rw-r-- 1 www www 1243347 Jun 28 22:45 web-demo_123_2017-06-26-12-18-09.tar.gz
drwxr-xr-x 5 www www 4096 Jun 26 12:18 web-demo_123_2017-06-26-12-18-57
-rw-rw-r-- 1 www www 1243369 Jun 28 22:46 web-demo_123_2017-06-26-12-18-57.tar.gz
-rw-rw-r-- 1 www www 45 Jun 29 06:21 web-demo__2017-06-30-14-28-54.tar.gz
drwxrwxr-x 2 www www 4096 Jun 30 14:30 web-demo__2017-06-30-14-30-22
-rw-rw-r-- 1 www www 130 Jun 29 06:23 web-demo__2017-06-30-14-30-22.tar.gz
drwxrwxr-x 2 www www 4096 Jun 30 14:31 web-demo__2017-06-30-14-31-53
-rw-rw-r-- 1 www www 219 Jun 29 06:24 web-demo__2017-06-30-14-31-53.tar.gz
drwxrwxr-x 4 www www 4096 Jun 30 14:59 web-demo_75463f1b_2017-06-30-14-59-58
-rw-rw-r-- 1 www www 1236456 Jun 29 06:52 web-demo_75463f1b_2017-06-30-14-59-58.tar.gz
drwxrwxr-x 4 www www 4096 Jun 30 15:05 web-demo_75463f1b_2017-06-30-15-05-57
-rw-rw-r-- 1 www www 1236450 Jun 29 06:58 web-demo_75463f1b_2017-06-30-15-05-57.tar.gz
drwxrwxr-x 4 www www 4096 Jul 10 14:01 web-demo_75463f1b_2017-07-10-14-01-34
-rw-rw-r-- 1 www www 1236446 Jul 10 14:01 web-demo_75463f1b_2017-07-10-14-01-34.tar.gz
drwxrwxr-x 4 www www 4096 Jun 30 15:18 web-demo_78869143_2017-06-30-15-18-29
-rw-rw-r-- 1 www www 1236465 Jun 29 07:11 web-demo_78869143_2017-06-30-15-18-29.tar.gz
drwxrwxr-x 4 www www 4096 Jul 10 14:00 web-demo_78869143_2017-07-10-14-00-35
-rw-rw-r-- 1 www www 1236453 Jul 10 14:00 web-demo_78869143_2017-07-10-14-00-35.tar.gz
drwxrwxr-x 3 www www 4096 Jun 30 14:14 web-demo_91d09cc2_2017-06-30-14-14-42
-rw-rw-r-- 1 www www 1236371 Jun 29 06:06 web-demo_91d09cc2_2017-06-30-14-14-42.tar.gz
drwxrwxr-x 3 www www 4096 Jun 30 14:15 web-demo_91d09cc2_2017-06-30-14-15-16
-rw-rw-r-- 1 www www 1236382 Jun 29 06:08 web-demo_91d09cc2_2017-06-30-14-15-16.tar.gz
drwxrwxr-x 4 www www 4096 Jul 10 14:08 web-demo_9a43cf55_2017-07-10-14-08-46
-rw-rw-r-- 1 www www 1233708 Jul 10 14:08 web-demo_9a43cf55_2017-07-10-14-08-46.tar.gz
drwxrwxr-x 4 www www 4096 Jun 30 15:21 web-demo_b8f3be43_2017-06-30-15-21-55
-rw-rw-r-- 1 www www 1236454 Jun 29 07:14 web-demo_b8f3be43_2017-06-30-15-21-55.tar.gz
drwxrwxr-x 4 www www 4096 Jul 10 12:34 web-demo_b8f3be43_2017-07-10-12-34-00
-rw-rw-r-- 1 www www 1236462 Jul 10 12:34 web-demo_b8f3be43_2017-07-10-12-34-00.tar.gz
drwxrwxr-x 4 www www 4096 Jun 30 14:57 web-demo_dcfb44f0_2017-06-30-14-57-10
-rw-rw-r-- 1 www www 1236447 Jun 29 06:50 web-demo_dcfb44f0_2017-06-30-14-57-10.tar.gz
1.4.2:回滾任意版本就將版本的參數(shù)傳遞給腳本,腳本會(huì)將web-demo的鏈接重新指向傳遞的版本(參數(shù)),比如我要回滾到web-demo_78869143_2017-06-30-15-18-29這個(gè)版本,則jenkins的配置為:
1.4.3:在jenkins執(zhí)行回滾:
1.4.4:執(zhí)行回滾的信息:
1.4.5:訪問(wèn)web界面測(cè)試任意版本回滾是否成功:
《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專(zhuān)家共同創(chuàng)作,文字、視頻、音頻交互閱讀總結(jié)
以上是生活随笔為你收集整理的jenkins运行日志时间与linux,持续集成之Jenkins结合脚本实现代码自动化部署及一键回滚至上一版本...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: linux系统一下剪贴板在哪里,Linu
- 下一篇: linux命令行引导iso,如何在Lin