南天一柱 发表于 2018-1-6 20:38:13

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]
查看完整版本: Jenkins进阶系列之