《Linux 进程管理进阶:会话、进程组与守护进程的底层逻辑与实践》

《Linux 进程管理进阶:会话、进程组与守护进程的底层逻辑与实践》
前引:在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!

目录

【一】会话

【二】前/后台进程

前台切后台进程:

查看后台进程:

后台切前台进程:

暂停后台进程:

继续运行后台进程:

【三】进程组与守护进程

(1)查看进程组

(2)守护进程

(3)守护进程原理

(4)如何创建守护进程


【一】会话

“会话”可理解为一个区域,通常一个用户登录就是一个会话,每个“会话”之前是并行的,即一个会话关闭不影响另外一个会话,在这个会话里面有许多的进程,例如:

用户登录打开的是解析OS命令的应用程序,处于OS与用户中间

注意:bash进程不是OS子进程,而是用来解析用户命令给OS的应用程序子进程

【二】前/后台进程

谁是前台/后台进程取决于谁拥有键盘,例如:键盘的Ctrl+C信号只对当前的前台进程有用

每个会话区只允许存在一个前台进程,其它只能为后台进程,那么如何互相切换?

前台切后台进程:
在命令末尾加  &,进程会被丢到后台运行(例如:./Ceshi  &)

例如:此时它变为了后台进程,是看不懂键盘输入的

查看后台进程:
执行指令 jobs ,即可查看后台进程,其中最前面的数字是作业编号(理解为后台进程编号)

例如:

后台切前台进程:
执行指令 用 fg %作业号 可以把后台作业拉到前台运行

例如:

暂停后台进程:
这里我们就采用19号信号来暂停后台进程(fg 作业号是切换到前程,我喜欢19号信号!)
继续运行后台进程:
执行指令 bg 作业号后台暂停的进程即可继续运行

【三】进程组与守护进程

(1)查看进程组

在上面我们提到了“会话”,一个会话中会存在n个进程组:相关联的进程集合

注意:前台进程组是唯一的,但前台进程组并非只有一个进程,比如:ls -l | grep ".txt" | wc -l
进程组的创建者(第一个进程)就是该进程组的组长(组长进程的 PID 就是组员的PGID

组内所有进程都继承组长的 PGID,直到组长退出或进程被迁移到其他组

简单粗暴,可使用指令:ps -efj

  • -e: 显示系统内所有进程
  • -f: 显示完整的信息(包括 UID, PID, PPID, C, STIME, TTY, TIME, CMD)
  • -j: 显示与作业控制相关的信息(包括 PGID, SID)

参数含义:

字段含义与进程组的关系
UID用户 ID进程的所有者
PID进程 ID每个进程唯一的标识符
PPID父进程 ID创建该进程的进程 ID
PGID进程组 ID核心字段! 同一个进程组内的所有进程拥有相同的 PGID。通常,进程组的组长进程的 PID 等于 PGID
SID会话 ID进程所属会话的 ID。一个会话可以包含多个进程组
CCPU 使用率进程使用的 CPU 百分比
STIME启动时间进程开始运行的时间
(2)守护进程

守护进程:守护进程是运行在后台的特殊进程,它独立于控制终端,不受用户登录或注销的影响,如何理解:我们的计算机桌面窗口可以理解为一个会话窗口,守护进程单独成一个会话窗口

(3)守护进程原理

主要原理:原进程A由父进程管理,而父进程主动退出,子进程A就变为了孤儿进程,父进程变为该会话的第一个进程,比如bash进程,再通过系统调用让A进程脱离这个终端/会话(不接受终端退出时的信号操作),成为守护进程(kill -9  -19这两个特殊的信号除外)

(4)如何创建守护进程
创建子进程,父进程主动退出:
pid_t t =fork(); if(t>0)exit(0); else { }
子进程单独成为会话:使子进程成为会话首进程,脱离原终端
setsid();
忽略一定的信号:
signal(SIGHUP, SIG_IGN); signal(SIGSTOP,SIG_IGN); .......
切换工作目录:
chdir("/");
设置文件权限掩码为 0:确保创建的文件和目录拥有最大的权限
umask(0);
可以将守护进程的日志信息打印到 /dev/null(垃圾站):
const std::string ptr ="/dev/null"; int fd = open(ptr.c_str(),O_RDWR); if(fd>0) { dup2(fd,0); dup2(fd,1); dup2(fd,2); }
                                         请忽略以下信息(仅限凑分使用):

在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!在 Linux 的世界里,进程并非孤立存在。当我们执行一条命令、启动一个服务时,这些进程会以会话(Session)为 “社交圈”、进程组(Process Group)为 “小团体” 的形式组织起来;而那些在后台默默运行、不受终端影响的守护进程(Daemon),更是 Linux 系统稳定运行的 “幕后英雄”!

Read more

(计算机源码可直接用)非物质文化遗产管理系统的设计与开发--98950 JAVA、PHP、爬虫、APP、小程序、C# 、C++、python、数据可视化、大数据、全套文案等.

(计算机源码可直接用)非物质文化遗产管理系统的设计与开发--98950 JAVA、PHP、爬虫、APP、小程序、C# 、C++、python、数据可视化、大数据、全套文案等.

由于篇幅限制,想要获取完整文章或者源码,拉到文章底部即可 感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人 。 摘   要 随着非物质文化遗产保护工作的深入推进,数字化管理成为提升保护效率的重要手段。本研究基于当前非遗保护中存在的信息分散、管理效率低等问题,提出开发一套非物质文化遗产管理系统,旨在通过现代化信息技术实现非遗资源的规范化、高效化管理,为非遗文化的传承与传播提供技术支持。 系统采用Django框架进行后端开发,前端使用Vue.js,结合Python语言实现业务逻辑处理,并使用MySQL数据库完成数据存储与管理。系统主要实现了用户管理、文化遗产管理、留言反馈、资讯管理等功能模块,同时引入Redis缓存技术优化性能与用户体验。此外,通过角色权限控制确保系统的安全性与稳定性。 本系统的开发不仅提高了非遗管理工作的效率,还为非遗文化的数字化保护提供了新的思路。它有助于扩大非遗文化的影响力,促进社会公众对非遗的关注与参与。同时,系统的开放性和可扩展性为未来非遗管理的进一步完善奠定了基础,具有重要的实践价值和

By Ne0inhk
前端基础知识

前端基础知识

前端基础知识 * HTML * HTML基本概念 * HTML常用标签 * 表格标签table * 表单标签 * CSS * CSS引入方式 * CSS选择器 * 常用的CSS * JavaScript * JavaScript基本概念 * 基础语法 * JavaScript对象 * JQuery * 猜数字案例 HTML HTML基本概念 HTML(Hyper Text Markup Language), 超⽂本标记语⾔ 超文本:比文本更强大,可以表示图片、音频、视频等等 其中通过标签进行控制,这些标签都是定义好的 <h1>一级标题</h1><h2>二级标题</h2><h3>三级标题&

By Ne0inhk
【Java 开发日记】我们来说一下消息的可靠性投递

【Java 开发日记】我们来说一下消息的可靠性投递

目录 1. 核心概念 2. 面临的挑战 3. 关键实现机制 3.1 生产端保证 3.2 Broker端保证 3.3 消费端保证 4. 完整可靠性方案 4.1 事务消息方案(如RocketMQ) 4.2 最大努力投递方案 4.3 本地消息表方案(经典) 5. 高级特性与优化 5.1 顺序性保证 5.2 批量消息可靠性 5.3 监控与对账 6. 不同MQ的实现差异 7. 实践建议 总结 面试回答 1. 核心概念 可靠性投递(Reliable

By Ne0inhk
Java 大视界 -- Java 大数据机器学习模型在自然语言处理中的少样本学习与迁移学习融合

Java 大视界 -- Java 大数据机器学习模型在自然语言处理中的少样本学习与迁移学习融合

Java 大视界 -- Java 大数据机器学习模型在自然语言处理中的少样本学习与迁移学习融合 * 引言:从虚拟偶像情感计算到语言智能的 “显微镜” 革命 * 正文:从理论架构到工业落地的全链条创新 * 一、NLP 领域的 “数据贫困” 困境与破局逻辑 * 1.1 少样本场景的核心挑战 * 1.2 Java 大数据的 “三维穿透” 技术架构 * 二、工业级融合模型的技术实现与代码解析 * 2.1 预训练模型迁移优化(BERT 医疗领域深度微调) * 2.2 原型网络(Prototypical Network)少样本分类 * 三、实战案例:从医疗语义分析到跨境电商智能客服 * 3.1 医疗场景:罕见病实体识别的 “样本逆袭” * 3.2 跨境电商:阿拉伯语商品类目分类的

By Ne0inhk