脚本功能:
通过定时计划任务运行该脚本,定期上传指定文件。
之前写了这个脚本,有时候网络不稳定的时候,总是上传失败。写了循环去传,但是苦于不知道怎样去获取FTP返回的错误状态,后来度娘到可以把ftp的运行错误日志记录写到文件中,因这个点来源于分享。因此,现在把整个脚本给分享出来,提供给大家一个思路。
通过检测这个错误日记录,并返回的状态,去循环上传指定文件,并追加脚本运行日志记录,以便于跟踪脚本运行情况。
#!/bin/bash #upload gonet log to ftp_server #by colin on 2015-07-23 scripts_run_log='/var/log/cron_scripts_run.log' echo "`date +%F" "%T":"%N` Script : $0 will runing..." >> ${scripts_run_log} gonetdir='/data/logs/www/' ftp_log_dir='/nginxlog/testnet' ############################# t_month=`date +%Y%m` t_last_hour=`date -d '1 hour ago' +%H` t_yesterday=`date -d "yesterday" +%d` t_today=`date +%d` T=`echo $(date +%k) |sed 's/ //g'` #凌晨的时候,文件目录是昨天的 if [ $T -eq 0 ];then temp_gonetdir=${gonetdir}${t_month}/${t_yesterday}/ else temp_gonetdir=${gonetdir}${t_month}/${t_today}/ fi put_log_name="yjww_${t_last_hour}.log" ftp_err_dir="/tmp/ftp_err/" [ -d ${ftp_err_dir} ] || mkdir -p ${ftp_err_dir} ftp_err_log="${ftp_err_dir}ftp_temp_yjww_err.log" #FTP自动化上传函数 send_gonet_log() { ftp -i -n FTP服务器的IP地址 21 2>${ftp_err_log} << _EOF_ user 用户名 密码 passive bin lcd ${temp_gonetdir} cd ${ftp_log_dir} put ${put_log_name} bye _EOF_ #统计前面FTP运行输出的错误日志记录行数 log_count=`cat ${ftp_err_log}|wc -l` [ ${log_count} -eq 0 ] && return 0 || return 1 } ########################## #调用FTP上传函数,返回until需要的状态值 #每次睡眠120秒,总循环三次 function run_send_gonet(){ send_gonet_log if [ $? -eq 0 ];then echo "`date +%F" "%T":"%N` Send : ${put_log_name} to ftp_server was successfully." >> ${scripts_run_log} return 0 else echo "`date +%F" "%T":"%N` Send : ${put_log_name} more than $x time." >> ${scripts_run_log} sleep 120 return 1 fi } #循环3次,总共6分钟 x=1 i=1 until [ "$i" -eq 0 ];do [ $x -gt 3 ] && { echo "`date +%F" "%T":"%N` Send : ${put_log_name} to ftp_server was failed, Please check..." >> ${scripts_run_log} exit } run_send_gonet i=`echo $?` x=`expr $x + 1` done #删除FTP产生的临时错误日志文件 [ -f ${ftp_err_log} ] && rm ${ftp_err_log} echo "`date +%F" "%T":"%N` Script : $0 done." >> ${scripts_run_log}