1、不记录日志的 SHELL 脚本就是耍流氓!
我们经常在工作中会遇到一个苦恼的事情,一个 Shell 脚本到底干了什么,什么时候开始执行,什么时候结束的。尤其是数据库备份,我们想知道我们的 MySQL 数据库备份时间。所以给脚本加日志显得尤为重要。那么我们的脚本应该有一个日志的函数,专门用于记录日志:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | #!/bin/bash SHELL_NAME= "$0" SHELL_LOG= "/var/log/$SHELL_NAME.log" shell_log(){ log_info=$1 echo "`date '+%H:%M:%S'` : $SHELL_NAME $log_info" >> $SHELL_LOG } shell_log "script start excupt......." sleep 3 shell_log "shell success........." # 上面的脚本我编写了一个日志函数shell_log,每次记录日志,我们直接执行shell_log把日志内容 当作第一个参数传给它就可以了,赶紧试试。 [root@zabbix_server /mnt ] # cat /var/log/mysql.sh.log 06:18:33 : mysql.sh script start excupt....... 06:18:36 : mysql.sh shell success......... |
2、直接就能执行的Shell脚本很容易耍流氓?
一个脚本直接就能执行?难道不是直接就能执行吗?试想,你临时编写了一个特别重要的脚本,干的事情可能有破坏性,一不小心被别人./执行了怎么办呢?而且很多时候我们一个脚本的功能可能有多个,所以我们有必要让用户可以选择进行执行。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 | #!/bin/bash # Shell Env SHELL_NAME= "shell_template.sh" SHELL_DIR= "/opt/shell" SHELL_LOG= "${SHELL_DIR}/${SHELL_NAME}.log" LOCK_FILE= "/tmp/${SHELL_NAME}.lock" #Write Log shell_log(){ LOG_INFO=$1 echo "$(date " +%Y-%m-%d ") $(date " +%H-%M-%S ") : ${SHELL_NAME} : ${LOG_INFO}" >> ${SHELL_LOG} } # Shell Usage shell_usage(){ echo $ "Usage: $0 {backup}" } # Backup MySQL All Database with mysqldump or innobackupex mysql_backup(){ shell_log "mysql backup start" shell_log "mysql backup stop" } # Main Function main(){ case $1 in backup) mysql_backup ;; *) shell_usage; esac } #Exec main $1 # 上面的脚本我们编写了shell_usage函数,用来告诉用户,这个脚本的使用方法。同时,我要强调一下 ,像编写Shell, 我们经常是面向过程的,建议以函数为单位,这样脚本非常的清晰可读。赶紧执行以下 看看效果吧。 [root@zabbix_server /mnt ] # sh mysql.sh Usage: mysql.sh {backup} |
对于一个功能脚本来说,貌似还少了点什么。对,就是注释!我们要说明白这个脚本是干啥的。或者以后你离职后,别人看到这个脚本之后,我擦,这么牛掰的脚本是谁写的呢?不要怕,写上你的大名。
1 2 3 4 5 6 7 8 9 | ################################## # $Name: shell_template.sh # $Version: v1.0 # $Function: Backup MySQL Databases Template Script # $Author: Jason Zhao # $organization: https://www.unixhot.com/ # $Create Date: 2016-08-27 # $Description: You know what i mean,hehe ################################### |
当然还有很多编写脚本的技巧,没法一一描述,不过如果能掌握上面的三种技巧,立马感觉编写的脚本有点高大上,有木有?
本文转自 运维小学生 51CTO博客,原文链接:http://blog.51cto.com/yasar/1880949,如需转载请自行联系原作者