Jenkins进阶系列之
#!/bin/bash# ------------------------------------------------------
# Jenkins的Subversion备份脚本
# 请将本脚本放到JENKINS_HOME目录
# 作者:zjl
# version:4.1
# time:2014-07-25 17:36
#
# 更新日志
# version:4.1
# 修护删除文件导致版本过时提交失败的bug
# version:4.0
# 修护从${TMP_STATUS_LOG}文本读取一行,变量前空格丢失的bug
# 修护从${TMP_STATUS_LOG}文本截取文件名某些情况错误的bug
# 优化脚本对特殊路径的处理
# 添加svn commit失败邮件告警功能
# 删除add 、commit时强制指定的用户
# version:2.0
# 修改Jenkins文件删除后不能自动从版本控制删除的bug
# 检出命令:svn co https://192.168.xxx.xxx/svn/Jenkins/trunk /home/froad/.jenkins/--username jenkins
#
# ------------------------------------------------------
# 获取当前系统时间分割日志文件(如果错误时邮件内容过大,可以将时间写的更精确)
# 精确到分钟
# DATE=`date "+%Y%m%d%H%M"`
# 精确到小时
DATE=`date "+%Y%m%d%H"`
# SVN_HOME的路径
SVN_HOME="/home/froad/svn"
# SVN程序的路径
SVN="${SVN_HOME}/bin/svn"
# JENKINS_HOME的路径
JENKINS_HOME="/home/froad/jenkins"
# 邮件告警设置
# 收件人(多个收件人用空格或逗号分隔)
MAIL_TO="xxx@qq.com"
# 伪造发件人(不能和收件人的邮件后缀相同,否则发送不了邮件)
MAIL_FROM="jenkins_svn@163.com"
# 主题/标题
MAIL_SUBJECT="Jenkins SVN commit fail !"
# 邮件发送类型
# 0:通用普通,163、QQ等邮箱会识别成垃圾邮件
# 1:Centos 6.x Mail version 12.4 7/29/08.
# 2:Centos 5.x Mail version 8.1 6/6/93.
# 请根据自己的Mail版本选择使用
MAIL_TYPE="1"
# 日志文件
LOG_HOME="/root/.subversion/logs"
LOG_FILE="${LOG_HOME}/svn_commit_${DATE}.log"
# svn_status日志文件
TMP_STATUS_LOG="${LOG_HOME}/status.log"
# svn_add 方法已停止使用,由svn_status代替。
#function svn_add()
#{
#使用svn add命令将文件添加到版本控制
# "${SVN}" add"${JENKINS_HOME}/*" --force &>>"${LOG_FILE}"
#退出码
# EXIT_NUM=$?
# echo "svn add退出码:${EXIT_NUM} !" >>"${LOG_FILE}"
#}
function send_mail(){
# 检查邮件参数
# 收件人为空
if [ -z "${MAIL_TO}" ];then
echo "MAIL_TO 参数为空!">>"${LOG_FILE}"
return
fi
# 伪造发件人发送时,发件人为空
if [ "${MAIL_TYPE}"=="1" -o "${MAIL_TYPE}"=="2" ];then
if [ -z "${MAIL_FROM}" ];then
echo "MAIL_FROM 参数为空!">>"${LOG_FILE}"
return
fi
fi
# LC_ALL=zh_CN.UTF-8 保证发送邮件时中文不会乱码
# mail相关请查看 http://ju.outofmemory.cn/entry/24406
if [ "${MAIL_TYPE}"=="1" ] ;then
# 1:Centos 6.x Mail version 12.4 7/29/08.
LC_ALL=zh_CN.UTF-8 mail -s "${MAIL_SUBJECT}" -r "${MAIL_FROM}" "${MAIL_TO}"< "${LOG_FILE}"
elif [ "${MAIL_TYPE}"=="2" ] ;then
# 2:Centos 5.x Mail version 8.1 6/6/93.
LC_ALL=zh_CN.UTF-8 mail -s "${MAIL_SUBJECT}" "${MAIL_TO}" -- -f "${MAIL_FROM}" < "${LOG_FILE}"
else
# 0:通用普通,163、QQ等邮箱会识别成垃圾邮件
# 注意:此方法可能会被163等邮箱识别为垃圾邮件
LC_ALL=zh_CN.UTF-8 mail -s "${MAIL_SUBJECT}""${MAIL_TO}" < "${LOG_FILE}"
fi
}
function svn_status()\
{
# 使用svn status命令判断文件是否删除、修改或者其他操作
"${SVN}" status"${JENKINS_HOME}" > "${TMP_STATUS_LOG}"
# 从文件中读取一行
cat "${TMP_STATUS_LOG}" | while read line;do
# 从文本中读取回来的内容必须用引号,不然前面的空格会丢失
# 获取第一个字符,根据第一个字符判断情况
l=`echo "${line}"|cut -c1`
# 获取文件的相对路径(获取第8个字符后的所有内容,前6个字符是svn的状态,2个字符间隔)
# 详细状态请查询:http://www.subversion.org.cn/svnbook/nightly/svn.ref.svn.c.status.html
f=`echo "${line}" | cut -c9-`
# 状态为A(增加)时,不需要任何操作,直接返回。
if [ "${l}" == "A"];then
continue
fi
# 状态为D(删除)时,不需要任何操作,直接返回。
if [ "${l}" == "D"];then
continue
fi
# 状态为M(修改)时,不需要任何操作,直接返回。
if [ "${l}" == "M"];then
continue
fi
# 状态为I(忽略)时,不需要任何操作,直接返回。
if [ "${l}" == "I"];then
continue
fi
# 状态为?(未受控制)时,调用add命令然后返回。ps:不知道怎么的有时候从文件中读取回来的?变成了0
if [ "${l}" == "0" ] || [ "${l}" == "?"];then
"${SVN}" add"${JENKINS_HOME}/${f}" >>"${LOG_FILE}"
continue
fi
# 状态为!(丢失或者不完整)时,调用delete命令然后返回。
if [ "${l}" == "!"];then
"${SVN}" delete "${JENKINS_HOME}/${f}" >>"${LOG_FILE}"
continue
fi
echo "其他情况:${line}" >>"${LOG_FILE}"
done
# 删除临时文件
# rm -rf ${TMP_STATUS_LOG}
}
function svn_update()
{
echo "svn update ...">>"${LOG_FILE}"
"${SVN}" update &>>"${LOG_FILE}"
svn_commit
}
function svn_commit()
{
# 使用svn commit命令提交到服务器
"${SVN}" commit--message="crontab commit" &>>"${LOG_FILE}"
EXIT_NUM=$?
if [ ! ${EXIT_NUM} == "0" ];then
if [ -z ${ISOUTOFDATE} ];then
# 确保这个if只执行一次
ISOUTOFDATE="1"
# 判断是否需要更新后在尝试提交(默认查找最后10行,-n xx指定行数)
isUpdate=`tail "${LOG_FILE}"| grep "is out of date"`
echo "+:${isUpdate}"
if [ ! -z "${isUpdate}" ];then
svn_update
return
fi
fi
echo "退出码:${EXIT_NUM} svn commit失败,请查看日志!">>"${LOG_FILE}"
# 调用发送mail方法
send_mail
return
fi
echo "svn commit退出码:${EXIT_NUM} !">>"${LOG_FILE}"
}
echo " 当前时间:`date "+%Y%m%d_%H%M%S"`" >>"${LOG_FILE}"
if [ ! -d "${LOG_HOME}" ];then
mkdir -p "${LOG_HOME}"
fi
# 进入到svn工作目录,防止出现稀奇古怪的错误
cd "${JENKINS_HOME}"
# 调用方法
svn_status
svn_commit
echo " 当前时间:`date "+%Y%m%d_%H%M%S"`" >>"${LOG_FILE}"
# 输出空行隔离
echo>>"${LOG_FILE}"
页:
[1]