可传递到子进程的全局变量:export
只在当前进程的全局变量:不带关键字
只在当前函数的局部变量:local
标准输入输出bash test.sh 1> normal.log #等价于 bash test.sh > normal.logbash test.sh 2> error.logbash test.sh 2> error.log 1>normal.log bash test.sh 2> total.log 1> total.log #等价于 bash test.sh > total.log 2>&1bash test.sh > /dev/null 2>&1 #不作任何输出
脚本执行 脚本执行参数-e 加上这个参数,任一命令执行失败,脚本会立即终止(shell里命令执行成功返回的状态码是0)
-x 加上这个参数,会在输出里显示每一条执行的命令本身,便于调试,但是一些涉及密码的操作,记得+x隐藏
#!/bin/bashset -execho 1 #由于set -x,脚本执行时会在控制台输出echo 1这条命令,以及1这个命令执行结果set +xecho 2 #由于set +x,脚本执行时只会输出2这个命令执行结果echo $? #命令执行成功,输出0状态码set -x #重新打开set +eabc #abc是个不存在的命令,但是set +e,所以不会导致脚本终止,后面的命令会继续执行echo $? #命令执行失败,输出非0状态码set -edef #由于set -e,不存在def这个命令,整个脚本会直接终止,后面的命令不再执行echo 3 #不会执行到
脚本导入存在1.sh和2.sh,在同级目录下。
在1.sh里使用2.sh里的函数或变量,只需执行source 2.sh。
子进程使用#!/bin/bashset -exfunction suc(){ echo suc sleep 5}function fail(){ echo fail sleep 10 abc #不存在的命令,返回错误状态码 echo 'fail end' #不会被执行到}suc & #在后台进程执行suc_pid=$! #获取上条命令的进程idfail &fail_pid=$!wait $fail_pid #等待进程执行结束,由于$fail_pid对应的进程返回状态码不为0,又设置了set -e,故此命令直接导致整个脚本终止wait $suc_pid #这条命令不会被执行到
命令的恰当使用举个例子,如下命令能将系统占用cpu最高的10个进程终止掉(把echo 换成kill -9)
ps -aux --sort=-%cpu | head -n 10 | awk '{print $2}' | sed 1d | sort -n | xargs -I {} echo {}