1、不记录日志的 SHELL 脚本就是耍流氓!
我们经常在工作中会遇到一个苦恼的事情,一个 Shell 脚本到底干了什么,什么时候开始执行,什么时候结束的。尤其是数据库备份,我们想知道我们的 MySQL 数据库备份时间。所以给脚本加日志显得尤为重要。那么我们的脚本应该有一个日志的函数,专门用于记录日志:
#!/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把日志内容 当作第一个参数传给它就可以了,赶紧试试。 [[email protected]_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脚本很容易耍流氓?
一个脚本直接就能执行?难道不是直接就能执行吗?试想,你临时编写了一个特别重要的脚本,干的事情可能有破坏性,一不小心被别人./执行了怎么办呢?而且很多时候我们一个脚本的功能可能有多个,所以我们有必要让用户可以选择进行执行。
#!/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, 我们经常是面向过程的,建议以函数为单位,这样脚本非常的清晰可读。赶紧执行以下 看看效果吧。 [[email protected]_server /mnt]# sh mysql.sh Usage: mysql.sh {backup}
对于一个功能脚本来说,貌似还少了点什么。对,就是注释!我们要说明白这个脚本是干啥的。或者以后你离职后,别人看到这个脚本之后,我擦,这么牛掰的脚本是谁写的呢?不要怕,写上你的大名。
################################## # $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 ###################################
当然还有很多编写脚本的技巧,没法一一描述,不过如果能掌握上面的三种技巧,立马感觉编写的脚本有点高大上,有木有?
时间: 2024-10-12 06:40:52