shell 脚本实战笔记(1)--source/fork/exec的区别

在linux shell编程中, 随着脚本处理规模的变大, 会嵌套调用子进程. 但父进程以不同的方式调用子进程, 其结果和背后的机制不尽相同.
这边就简单描述下source/fork/exec调用子进程的区别.

编写如下脚本

executor.sh

1 #! /bin/bash
2 
3 echo "script:$0, pid: $$"


分别以source/fork/exec调用子脚本的代码片段

 1 echo "script:$0 pid: $$, tag 1"
 2 source ./executor.sh
 3 echo "script:$0 pid: $$, tag 2"
 4 
 5 /*
 6 source 执行结果如下:
 7 script:./example.sh pid: 7862, tag 1
 8 script:./example.sh, pid: 7862
 9 script:./example.sh pid: 7862, tag 2
10 */
 1 echo "script:$0 pid: $$, tag 1"
 2 ./executor.sh
 3 echo "script:$0 pid: $$, tag 2"
 4 
 5 /*
 6 fork 执行结果如下:
 7 script:./example.sh pid: 7862, tag 1
 8 script:./executor.sh, pid: 7863
 9 script:./example.sh pid: 7862, tag 2
10 */
1 echo "script:$0 pid: $$, tag 1"
2 exec ./executor.sh
3 echo "script:$0 pid: $$, tag 2"
4 
5 /*
6 exec 执行结果如下: 
7 script:./example.sh pid: 7862, tag 1 
8 script:/path/to/executor.sh, pid: 7862
9 */


从结果中, 我们可以得出: 在进程方面, 以source/exec的方式pid保持一致, 而fork的方式pid不同, 在执行流程方面, source/fork保留了父进程的执行流程,
exec方式, 则在调用后, 完全覆盖了父进程的后续流程.

参考: blog.csdn.net/zhuying_linux/article/details/6891436

总结如下:
exec/source属于bash内部命令
source命令: 在当前进程中执行子脚本文件中的各个命令
exec命令: 并不创建子进程, 用子脚本覆盖父脚本, 并执行
fork属于系统调用, 会创建一个子进程, 父进程会阻塞等待子进程执行结束, 然后继续往下执行

source/exec的另一个区别在于,source能使用调用脚本定义的本地变量,exec则不会,exec更像颠覆性的替换

环境变量的导入, 父进程会把环境变量(本地变量的区别)自动继承给子进程,而且这个方向是单向的,如何查看一个进程的环境变量
借助如下命令来实现:
cat /proc/<pid>/environ | tr '' ' '

原文地址:https://www.cnblogs.com/mumuxinfei/p/3680296.html