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 '\0' '\n'

 

 

 

 

 

 

posted on   mumuxinfei  阅读(1046)  评论(0编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示