变量作用域
可传递到子进程的全局变量:export
只在当前进程的全局变量:不带关键字
只在当前函数的局部变量:local
标准输入输出
bash test.sh 1> normal.log #等价于 bash test.sh > normal.log
bash test.sh 2> error.log
bash test.sh 2> error.log 1>normal.log
bash test.sh 2> total.log 1> total.log #等价于 bash test.sh > total.log 2>&1
bash test.sh > /dev/null 2>&1 #不作任何输出
脚本执行
脚本执行参数
-e 加上这个参数,任一命令执行失败,脚本会立即终止(shell里命令执行成功返回的状态码是0)
-x 加上这个参数,会在输出里显示每一条执行的命令本身,便于调试,但是一些涉及密码的操作,记得+x隐藏
#!/bin/bash
set -ex
echo 1 #由于set -x,脚本执行时会在控制台输出echo 1这条命令,以及1这个命令执行结果
set +x
echo 2 #由于set +x,脚本执行时只会输出2这个命令执行结果
echo $? #命令执行成功,输出0状态码
set -x #重新打开
set +e
abc #abc是个不存在的命令,但是set +e,所以不会导致脚本终止,后面的命令会继续执行
echo $? #命令执行失败,输出非0状态码
set -e
def #由于set -e,不存在def这个命令,整个脚本会直接终止,后面的命令不再执行
echo 3 #不会执行到
脚本导入
存在1.sh和2.sh,在同级目录下。
在1.sh里使用2.sh里的函数或变量,只需执行source 2.sh。
子进程使用
#!/bin/bash
set -ex
function suc(){
echo suc
sleep 5
}
function fail(){
echo fail
sleep 10
abc #不存在的命令,返回错误状态码
echo 'fail end' #不会被执行到
}
suc & #在后台进程执行
suc_pid=$! #获取上条命令的进程id
fail &
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 {}