Shell脚本中的set指令,⽐如set-x和set-e
set参数介绍
set指令能设置所使⽤shell的执⾏⽅式,可依照不同的需求来做设置
-a 标⽰已修改的变量,以供输出⾄环境变量。
-b 使被中⽌的后台程序⽴刻回报执⾏状态。
-C 转向所产⽣的⽂件⽆法覆盖已存在的⽂件。
-d Shell预设会⽤杂凑表记忆使⽤过的指令,以加速指令的执⾏。使⽤-d参数可取消。
-e 若指令传回值不等于0,则⽴即退出shell。
-f 取消使⽤通配符。
-h ⾃动记录函数的所在位置。
-H Shell 可利⽤"!"加<;指令编号>的⽅式来执⾏history中记录的指令。
shell代码
-k 指令所给的参数都会被视为此指令的环境变量。
-l 记录for循环的变量名称。
-m 使⽤监视模式。
-n 只读取指令,⽽不实际执⾏。
-p 启动优先顺序模式。
-P 启动-P参数后,执⾏指令时,会以实际的⽂件或⽬录来取代符号连接。
-t 执⾏完随后的指令,即退出shell。
-u 当执⾏时使⽤到未定义过的变量,则显⽰错误信息。
-v 显⽰shell所读取的输⼊值。
-x 执⾏指令后,会先显⽰该指令及所下的参数。
+<;参数> 取消某个set曾启动的参数。
set -x介绍
⽤于脚本调试,在liunx脚本中可⽤set -x就可有详细的⽇志输出.免的⽼是要echo了
set -e介绍
#!/bin/bash
set -e
command 1
command 2
...
exit 0
你写的每个脚本都应该在⽂件开头加上set -e,这句语句告诉bash如果任何语句的执⾏结果不是true则应该退出。这样的好处是防⽌错误像滚雪球般变⼤导致⼀个致命的错误,⽽这些错误本应该在之前就被处理掉。如果要增加可读性,可以使⽤set -o errexit,它的作⽤与set -e相同。
使⽤-e帮助你检查错误。如果你忘记检查(执⾏语句的结果),bash会帮你执⾏。不幸的是,你将⽆法检查$?,因为如果执⾏的语句不是返回0,bash将⽆法执⾏到检查的代码。你可以使⽤其他的结构:
command
if [ "$?"-ne 0]; then
echo "command failed";
exit 1;
fi
could be replaced with
能够被代替为
command || { echo "command failed"; exit 1; }
或者
if ! command; then
echo "command failed";
exit 1;
fi
如果你有⼀个命令返回⾮0或者你对语句执⾏的结果不关⼼,那你可以使⽤command || true,或者你有⼀段很长的代码,你可以关闭错误检查(不使⽤set -e),但是我还是建议你保守地使⽤这个语句。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论