shell 实现子进程多任务,进程高并发

news2025/1/14 1:05:39

多进程的作用

  1. 提高程序的效率:一些CPU密集型的任务,如数据处理、解压、加密等,使用多进程可以提高程序的执行效率,更快地完成计算任务;

  2. 实现更复杂的功能:多进程可以在同一时间向不同的方向处理不同的任务,可以利用这一特性实现更加复杂的功能。

目录

1. 了解实现多进程的方法

2. shell 子进程应用

3. shell 高并发


1. 了解实现多进程的方法

Linux 通过后台执行,语法如下:

command &
nohup command &
  • 两种方式都可以实现后台运行,但也存在区别。

1. 通过命令执行

command &:输出的结果显示到终端窗口,会随着终端窗口退出而退出(不建议)

nohup command &:自动将结果输出到 nohup.out 文件(即使异常提示)。这种方式不论是终端退出还是ssh断开,都不会影响后台进程运行

如果后台进程继续运行,可以通过 jobs 查看

推荐几个相关的命令

jobs  #查看后台运行的任务列表
bg    #将冻结的任务运行到后台( bg [jobs列表号] ),可以是 Ctrl + Z 停止的进程
fg    #将后台任务转到前台运行( fg [jobs列表号] )

  

2. 通过 shell 执行

  • 两者的区别和命令执行差不多,如果shell中使用的 command &,但是执行shell脚本的是 nohup src.sh & ,那么该子进程同样不会随着终端的退出而停止。

不加 nohup

加入 nohup

  

2. shell 子进程应用

直接在命令后面加 & 其实意义不到,可作用的范围小,一般用于函数的使用。

定义3个函数,用 & 方法将函数变换为子进程

proc1(){
echo "我是子进程1..."
sleep 1000
}

proc2(){
echo "我是子进程2..."
sleep 1000
}

proc3(){
echo "我是子进程3..."
sleep 1000
}

proc1 &
proc2 &
proc3 &

wait
echo "======== 结束 ========"
  • [函数名] & :表示子进程
  • wait:表示必须等待子进程结束才能执行下一步

使用 wait 等待子进程,所以主进程并不会退出。来看一下进程信息

 

如果不使用 wait,程序会继续向下执行

proc1(){
echo "我是子进程1..."
sleep 1000
}
proc1 &

echo "======== 当前进程情况 ========"
ps xl |grep $$ |grep -v grep

  • 可以看到在没有等待子进程的情况会直接向下执行,直到结束也不会停止子进程(此时的子进程的父进程已停止,变成了孤儿进程被进程1接收) 

 

那么如何解决孤儿进程呢?可以通过 trap 命令捕获异常,子进程随着主进程的退出而退出

trap "[命令1] ; [命令2] ; [命令3]..." EXIT
sleep 1000 &
cpid1="$!"
sleep 1001 &
cpid2="$!"
trap "kill -9 ${cpid1} ${cpid2} 2>/dev/null; echo '退出信号!'; exit" EXIT

echo "======== 当前进程情况 ========"
ps xl |grep $$ |grep -v grep
  • 通过 $! 获取子进程的PID,再使用 trap 捕获退出信号时将其杀死

 

3. shell 高并发

通过上述的方法了解的子进程实现的原理后,高并发就非常的简单(for循环)

proc1(){
for i in {1..10};do
        echo "我是子进程1" &
done
}
proc2(){
for i in {1..10};do
        echo "我是子进程2" &
done
}

proc1
proc2

wait

 

proc1(){
echo "我是子进程1"
}
proc2(){
echo "我是子进程2"
}

for k in {1..5};do
        proc1 &
        proc2 &
done

wait

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/665099.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot创建和运行

1、什么是SpringBoot1.1、优点 2、项目创建2.1、使用Idea创建2.2、使用网页创建 3、项目目录介绍4、项目运行5、包路径错误 1、什么是SpringBoot Spring是为了简化Java程序开发的。Spring Boot是一种用于快速构建独立、生产级别的Java应用程序的开源框架,是为了简化…

MySQL优化--undo log和redo log的区别

首先我们需要知道两个概念 缓冲池(buffer pool):主内存中的一个区域,里面可以缓存磁盘上经常操作的真实数据,在执行增删改查操作时,先操作缓冲池中的数据(若缓冲池没有数据,则从磁盘加载并缓存…

MySQL数据库基础 13

第十三章 约束 1. 约束(constraint)概述1.1 为什么需要约束1.2 什么是约束1.3 约束的分类 2. 非空约束2.1 作用2.2 关键字2.3 特点2.4 添加非空约束2.5 删除非空约束 3. 唯一性约束3.1 作用3.2 关键字3.3 特点3.4 添加唯一约束3.5 关于复合唯一约束3.5 删除唯一约束 4. PRIMARY…

燃气管网监测系统助力天燃气管道安全运行

随着城市化的进程,燃气管道网络在各个城市中越来越密集,一旦发生燃气泄漏等安全事故,后果将不堪设想。因此,城市燃气管网的建设发展有赖于制定一个安全可靠的监控方案,以保障供气管道与用户安全。物联网技术的发展为城…

北邮国院物联网RFID课程笔记

PDF 获取:微信公众号:灰海宽松,后台回复 “RFID” 获取。 文章目录 RFID1. IntroductionComparison of different automatic identification technologiesThe main features of RFIDConstraints of RFID technologyCore technologies of RFI…

一个cad绘图图型的过程

cad绘图步骤 : 1.设置绘图环境。 选择菜单栏中的“格式”→“图层”命令,新建 3 个图层: 第一图层命名为“粗实线”,线宽为 0.3mm,其余属性默认。 第二图层命名为“细实线”,线宽为 0.15mm,其…

计算机网络开荒5-数据链路层

文章目录 一、 数据链路层服务二、链路层具体实现三、差错检测3.1 差错编码3.2 奇偶校验吗3.3 Internet校验和checksum3.4 循环冗余校验码CRC 四、多路访问控制MAC协议4.1 理想的MAC协议4.2 MAC协议分类4.2.1 TDMA4.2.2 FDMA 4.3 随机访问控制协议4.3.1 时隙ALOHA协议4.3.2 ALO…

chatgpt赋能python:Python拆数指南:如何使用Python快速拆解数字

Python拆数指南:如何使用Python快速拆解数字 如果您正在开发一个关于数字的应用程序,那么您会发现Python可以非常方便地拆解数字。Python的拆数功能可以快速拆解数字并将其转换为可读的形式,这对于数据处理和编程任务来说非常有用。 Python…

JavaScript的数学计算库:decimal.js

An arbitrary-precision Decimal type for JavaScript. 功能 整数和浮点数简单但功能齐全的 API复制 JavaScript 和对象的许多方法Number.prototype Math还处理十六进制、二进制和八进制值比 Java 的 BigDecimal JavaScript 版本更快,更小,也许更容易使…

chatgpt赋能python:Python代码实现查找重复字符串

Python代码实现查找重复字符串 Python 是一种高级程序设计语言,被广泛用于网络编程、web开发、数据分析等领域。在 SEO 操作中,经常需要进行关键词分析,以确定哪些词汇是最重要的。本文将介绍如何使用 Python 实现查找重复字符串的代码。 什…

24连续Hopfield神经网络的优化旅行商问题优化计算(附matlab程序)

1.简述 学习目标: 连续Hopfield神经网络的优化旅行商问题优化计算 需要计算10个城市最优路径及总路径长度 hopfield可以分为离散型神经网络和连续型神经网络(DHNN\ CHNN) 在之前的文章中讲过的单层感知器和BP都是离散的,目前连续…

高效创作助手:ChatGPT最新版实现批量撰写聚合文章的全新水平

随着人工智能技术的不断发展,ChatGPT最新版作为一款智能创作助手,实现了批量撰写聚合文章的全新水平。它能够在短时间内生成高质量的文章,极大地提高了创作效率。本文将从随机8-20个方面对ChatGPT最新版进行详细的阐述,让我们一起…

C11 std::function 学习

此文, https://blog.csdn.net/bcbobo21cn/article/details/111658249 使用了一次C11 std::function,是作为函数指针使用的; 进一步的来说,C11的std::function可以对任何可以调用的目标实体进行调用操作; std::functi…

RFID课程要点总结_5 EPC

5. EPCglobal Standard & protocol Concept of EPC global network EPCglobal Network: a technology that allows trading partners to document and determine the location of individual goodsif possible in real timeadditional information: such as 生产使用日期…

golang代码规范之框架搭建规范

编写本规范的目的在于,让开发者更方便快捷地搭建项目框架,同时让团队内部的技术栈达到统一。 指导思想 框架搭建需要适应项目的变化,为项目选择最合适的架构,没有什么是一成不变的。技术架构应该是不断完善的,在满足当…

pytest 自动化学习

一 pytest简介与安装 def inc(x): return x1 def test_answer(): assert inc(3) 5 #判断 4会不会等5 二 Pytest 命令规则 三 pycharm配置与界面化运行 四 pytest测试用例结构 用例结构 三部分构成 1.用例名称用例步骤 2.编辑 3.断言…

Docker 进入容器和交换文件

1、进入容器 有些时候需要进入容器进行操作,使用 docker exec 命令,这个命令后面可以添加很多参数,我们这里只讲添加 -i 和 -it 参数。 只添加 -i 参数时,由于没有分配伪终端,界面没有我们熟悉的 Linux 命令提示…

人工智能第2章基于图的知识表示与图搜索技术(课后部分习题答案)

解:用四元组(f,w,s,g)表示状态,其中 f 表示猎人,w 表示狼, s 表示羊,g 表示草,其中每个元素都可以为 0 或 1,表示在左案, …

chatgpt赋能python:Python将图片转换为代码的顶级SEO文章

Python将图片转换为代码的顶级SEO文章 在当今数字化的世界中,图像和代码都是最为重要的元素之一。Python作为一种流行的编程语言,可以帮助我们将这两种元素结合起来,让我们从图像中提取出代码。本文将讨论Python如何将图像转换为代码&#x…

哈工大计算机网络传输层协议详解之:TCP协议

哈工大计算机网络传输层协议详解之:TCP协议 文章目录 哈工大计算机网络传输层协议详解之:TCP协议TCP概述TCP段结构序列号和ACKTCP可靠数据传输RTT和超时TCP发送方事件TCP发送端程序伪代码TCP重传示例TCP接收方 ACK生成TCP快速重传机制 TCP流量控制TCP连接…