/root/scripts/info..."/>
您好,登錄后才能下訂單哦!
#!/bin/bash
Port="8080"
BaseDir=/opt/build/workspace/www.why.cn/svn/target/why/
ConfigDir=/opt/build/workspace/www.why.cn/svn/configs
>/root/scripts/info.log
>/tmp/outprint-${Port}.log
rsync -vzrtopgl --delete --exclude .svn $ConfigDir/log4j.properties /opt/tomcat-8080/webapps/why/WEB-INF/classes/log4j.properties
rsync -vzrtopgl --delete --exclude .svn $ConfigDir/pro.properties /opt/tomcat-8080/webapps/why/WEB-INF/classes/pro.properties
rsync -vzrtopgl --delete --exclude .svn $ConfigDir/jdbc.properties /opt/tomcat-8080/webapps/why/WEB-INF/classes/jdbc.properties
rsync -vzrtopgl --delete --exclude .svn $ConfigDir/web.xml /opt/tomcat-8080/webapps/why/WEB-INF/web.xml
rsync -vzrtopgl --delete --exclude .svn $ConfigDir/common.js /opt/tomcat-8080/webapps/why/STATIC/js/common.js
rsync -vzrtopgl --delete --exclude pro.properties --exclude jdbc.properties --exclude log4j.properties --exclude web.xml --exclude common.js ${BaseDir} /opt/tomcat-8080/webapps/why/
[ $? -ne 0 ] && {
rm -rf $BaseDir/*
echo "發(fā)布失敗,請檢查?。?
pkill tail
exit 2
}
/usr/sbin/tomcat-8080 restart;tail -f /opt/tomcat-8080/logs/catalina.out >>/tmp/outprint-${Port}.log &
times=0
while true;do
#定義通過curl命令獲取網(wǎng)頁狀態(tài)碼的個數(shù)
crul_num=`curl -Is http://192.168.5.116:8080/frontIndex/index.do --connect-timeout 5 -m 5|head -n1|awk '{print $2}'|wc -l`
#當(dāng)返回值個數(shù)為0且經(jīng)過20s時間后就判斷此次發(fā)布失敗,打開網(wǎng)頁超時,直接退出。
[ ${crul_num} -eq 0 -a $times -eq 20 ] && {
echo "tomcat-${Port}: 項(xiàng)目已經(jīng)發(fā)布,但網(wǎng)頁打開超時,不能繼續(xù),請檢查!!" >>/root/scripts/info.log
cat /root/scripts/info.log
echo -e "\n\n\n\n###################錯誤日志如下##################\n\n\n\n"
sleep 2
tail -n 500 /tmp/outprint-${Port}.log
pkill tail
exit 2
}
#定義了當(dāng)獲取網(wǎng)頁狀態(tài)碼為0數(shù)的話就將時間增加1秒,直到上面的等于20就退出。
[ ${crul_num} -eq 0 ] && {
let times++
sleep 1
continue
}
#從上面可獲知狀態(tài)碼個數(shù)不為0,現(xiàn)在定義狀態(tài)碼的值是否為200,不為200就直接退出.
crul_flags=`curl -Is http://192.168.5.116:8080/frontIndex/index.do|head -n1|awk '{print $2}'`
[ ${crul_flags} -ne 200 ]&&{
echo "tomcat-${Port}: 項(xiàng)目已經(jīng)發(fā)布,但網(wǎng)頁打開超時,不能繼續(xù),請檢查!!" >>/root/scripts/info.log
cat /root/scripts/info.log
echo -e "\n\n\n\n###################錯誤日志如下##################\n\n\n\n"
sleep 2
tail -n 500 /tmp/outprint-${Port}.log
pkill tail
exit 3
}
#通過上面的判斷,頁面可以正常打開,發(fā)布正常,現(xiàn)將實(shí)例添加到nginx并重新加載。
echo "tomcat-${Port}: 發(fā)布成功!!" >>/root/scripts/info.log
break
done
#rm -rf $BaseDir/*
pkill tail
cat /root/scripts/info.log
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。