有个运维小哥的心都碎了,原因是服务器上有个也不知道是谁写的定时任务,在执行过程中遇错后,仍然继续……然后在一个不恰当的位置执行了“rm -rf”命令……也不知道说了多少遍,使用“rm -rf”命令时一定要谨慎,但是悲剧总是无休止地上演。
语法
set [参数]
参数说明
参数 | 说明 |
-a | 标示已修改的变量,以供输出至环境变量 |
-b | 使被中止的后台程序立刻回报执行状态 |
-C | 转向所产生的文件无法覆盖已存在的文件 |
-d | Shell预设会用杂凑表记忆使用过的指令,以加速指令的执行使用-d参数可取消 |
-e | 若指令传回值不等于0,则立即退出shell |
-f | 取消使用通配符 |
-h | 自动记录函数的所在位置 |
-H | Shell可利用"!"加<指令编号>的方式来执行history中记录的指令 |
-k | 指令所给的参数都会被视为此指令的环境变量 |
-l | 记录for循环的变量名称 |
-m | 使用监视模式 |
-n | 只读取指令,而不实际执行 |
-p | 启动优先顺序模式 |
-P | 启动-P参数后,执行指令时,会以实际的文件或目录来取代符号连接 |
-t | 执行完随后的指令,即退出shell |
-u | 当执行时使用到未定义过的变量,则显示错误信息 |
-v | 显示shell所读取的输入值 |
-x | 执行指令后,会先显示该指令及所下的参数 |
+<参数> | 取消某个set曾启动的参数 |
举例
在脚本中,通过“set -e”命令开启代码检测,当脚本执行时遇到错误便即刻退出,取消时使用“set +e”命令。
#!/bin/bash # 开启代码检测 set -e # set -o errexit 同 set -e aa rm -rf $aa ... # 关闭代码检测 set +e # set +o errexit 同 set +e ...
以上代码,变量aa定义错误,故不再继续执行脚本,关闭代码检测后则不会退出,我们可以看到脚本执行了echo命令,在文件夹中产生了testrm.txt文件。
补充:强烈建议大家在执行“rm”命令前检测待删除的目录是否正确或者存在。
#!/bin/bash pmtest="/var/waiting_for_rm" rmtest () { if [ -d ${pmtest} ]; then rm -rf ${pmtest} else echo "目录不存在" > /opt/rmtest.log # 其他命令…… fi }
原创文章禁止转载:技术学堂 » Linux脚本设置工具set命令使用方法及实例