一、sh方式
使用$ sh script.sh执行脚本时,当前shell是父进程,生成一个子shell进程,在子shell中执行脚本。脚本执行完毕,退出子shell,回到当前shell。 $ ./script.sh与$ sh script.sh等效。
例子
使用loop.sh脚本反复打印当前进程号。
$ vim loop.sh
while [ 1 = 1 ]; do
echo $$
export aaa="aaa"
export bbb="bbb"
echo $aaa $bbb
sleep 1
done
查看父shell的进程号。
[root@app01 linux]
12197
[root@app01 linux]
在loop.sh中,打印子shell进程号18313。
[root@app01 linux]
18313
aaa bbb
18313
aaa bbb
18313
aaa bbb
不停止循环,再打开一个shell,发现18313是12197的子进程
[root@app01 linux]
root 12197 12194 0 14:37 pts/0 00:00:00 -bash
root 18313 12197 0 17:26 pts/0 00:00:00 /bin/sh ./loop.sh
root 18461 11040 0 17:26 pts/1 00:00:00 grep --color=auto 12197
停止循环,打印变量为空。
[root@app01 linux]
[root@app01 linux]
二、source方式
使用$ source script.sh方式,在当前上下文中执行脚本,不会生成新的进程。脚本执行完毕,回到当前shell。source方式也叫点命令,$ . script.sh与$ source script.sh等效。注意在点命令中,.与script.sh之间有一个空格。
例子
loop.sh脚本的进程id和shell的相同
[root@app01 linux]
12197
[root@app01 linux]
12197
aaa bbb
12197
aaa bbb
12197
aaa bbb
停止循环,能够打印出 $aaa 的值
[root@app01 linux]
aaa
[root@app01 linux]
三、exec方式
使用exec command方式,会用command进程替换当前shell进程,并且保持PID不变。执行完毕,直接退出,不回到之前的shell环境。
四、使用sh和source方式对上下文的影响
在sh和source方式下,脚本执行完毕,都会回到之前的shell中。但是两种方式对上下文的影响不同呢。
此例中,jump.sh脚本执行如下操作:1)跳到/,2)打印当前工作目录,3)打印Hello。
$ vim jump.sh
cd /
pwd
echo Hello
#通过sh执行脚本时,修改的上下文不会影响当前shell。jump.sh退出以后,工作目录保持不变。
$ pwd
/home/riversec
$ ./jump.sh
/
Hello
$ pwd
/home/riversec
通过source执行脚本时,修改的上下文会影响当前shell。jump.sh退出以后,当前工作目录变成了/。
$ pwd
/home/riversec
$ source jump.sh
/
Hello
$ pwd
/
|