[Linux] 信号(singal)详解(二):信号管理的三张表、如何使用coredump文件、OS的用户态和内核态、如何理解系统调用?

标题:[Linux] 信号管理的三张表、如何使用coredump文件、OS的用户态和内核态、如何理解系统调用?

@水墨不写bug

(图片来源:文心一言)

正文开始:


目录

 一、信号管理的三张表

(1)三张表

(2)信号三张表实际意义的实例

(3)信号阻塞和忽略的区别

(4)signal捕捉信号的本质

二、coredump文件如何使用?

三、OS的用户态和内核态

四、如何理解系统调用?

1. 系统调用的作用

2. 系统调用的触发方式

3. 系统调用的执行流程


 一、信号管理的三张表

(1)三张表

 i、block位图(32位)

        比特位的位置:代表信号的编号

        比特位的内容:表示信号是否被阻塞:1表示对应的信号被阻塞,0表示对应的信号没有被阻塞。

ii、pending位图(32位)

         比特位的位置:表示信号的编号

         比特位的内容:表示信号是否收到:1表示信号被收到,但是还没有递达(处于未决状态),0表示信号没有处于未决状态。

iii、hander表

        hander表本质上不是位图,而是一张函数指针表,存有函数地址。

        表内数据的位置:表示信号的标号

        表内数据的内容:表示对应要调用的函数地址

        这三张表,是OS管理信号的根本依靠,他们实现了让OS通过两张位图+一张函数指针数组让OS内的进程可以识别信号!!

(2)信号三张表实际意义的实例

        举一个例子,具体来说,根据上面这个图的三张表表示的信号状态而言:

        1号信号:pending对应为0,表示没有产生过1好信号;block是0,表示1号信号没有被阻塞(1号信号一旦产生,就会被递达,在这之间可能会存在短暂的pending状态,但是这段时间非常短)。1号信号的函数指针数组存储为:SIG_DFL,表示按照默认的信号处理方式处理1号信号。

        2号信号:pending对应为1,表示产生了2号信号,但是同时block为1,表示2号信号被阻塞,所以产生的2号信号一直处于pending状态,而不会被递达。2号信号的函数指针数组存储为:SIG_IGN,表示处理方式是忽略2号信号。

        3号信号:pending为0,表示还没有捕捉到3号信号,3号信号的block为1,表示如果出现3号信号,3号信号会被阻塞而不递达。3号信号的处理方式是用户自定义处理的函数sighandler函数。

(3)信号阻塞和忽略的区别

        信号阻塞:是对信号是否递达的处理;

        信号忽略:是信号递达后的一种处理动作。

        被阻塞的信号产生时保持在未决状态,直到进程解除对这个信号的阻塞,然后才执行递达动作。

        阻塞和忽略不同,只要信号被阻塞就不会递达;忽略是信号被递达后采取的一种处理动作。

(4)signal捕捉信号的本质

         把用户提供的函数指针填入到对应的handler表中。

        某些信号无法被捕捉、忽略、阻塞——SIGKILL(9号信号)、SIGSTOP(19号信号)


二、coredump文件如何使用?

        其实这是一个以前就遇到过的问题:

信号的默认处理方式的core和term都是终止进程,这两种信号终止进程有什么不同?

        tem:    本质就是异常终止了进程;

        core:也是异常终止了进程;但是进程退出的时候(发生错误的时候)的镜像数据会被核心转储,最终会生成一个Debug文件,这个文件可以被调试器(比如cgbd使用)后面会进行讲解。

 注意:

        1.默认coredump被关闭。

        在旧版本的CentOS上,每一次生成的code文件的名字都是不同的,当大项目出错时,一般服务器会快速重启,若重复出错,会生成很多的core大文件,如果这样的错误是在晚上发生的,那么累计一晚上的core文件占用的空间很可能会让服务器爆盘,从而无法再启动服务器。

        2.如何打开codedump?

        指令:

        ulimit -c 10240

        表示允许生成的最大文件占用的块数为10240。当进程被信号杀掉后,会生成一个core文件。同时把返回的标志的第7位置1(coredump标志,这个标志表示是否形成了core文件)。

如何使用core文件?(以cgbd为例)

        当一个进程报错后,会产生core文件,我们可以打开cgbd来调试这个程序。

        打开gbd对指定的程序调试

指令:

        core -file + core文件名

        运行这条指令可以直接加载进程在崩溃时的错误信息,这样就可以直接定位出错的位置,同时可以直接查看出错时的各个变量的值,免去了找错的过程!


三、OS的用户态和内核态

         OS在执行我们写的代码的时候,会进行内核态和用户态的转变;

        在收到一个信号的时候,对应的信号的位置被置1,但是信号不会被立刻处理,而是在进程丛内核态将要返回用户态的时候,进行处理,具体过程如下:

        具体过程如下:

        1.执行主流程收到某一信号;

        2.进入内核处理异常之后,在回到用户态之前,处理进程中可以递达的信号。

        3.如果这个信号的处理动作是用户自己定义的函数,则OS会回到用户态,直接进入用户自定义函数的逻辑处(这里注意不是回到主流程!)。

        4.处理完用户自定义函数之后,调用特殊系统调用sigreturn返回内核态。

        5.返回用户态,然后回到主流程继续处理。直到再次检测到异常重复上述操作。 

总结来说,进行信号的检测和处理的阶段是在:进程从内核态返回用户态之前。 

对于内核态和用户态的地址空间的理解: (以32位机器为例)


        1.OS通过内核级页表找到内核空间;通过用户级页表找到用户空间。

        2.OS本身就在进程的地址空间中;

        3.不同进程对应不同份的用户级页表;对应同一份内核级页表——内核级页表只有一份,无论你进程如何切换,总能找到OS。

        4.用户访问OS,其实还是在地址空间当中进行的!这个过程和访问函数是一样的。

        5.但是用户访问OS只能通过一个方式:系统调用。


四、如何理解系统调用?

         在Linux系统中,系统调用(System Call)是用户空间程序与内核之间进行交互的核心机制。

首先需要理解:

        操作系统OS本质就是一个死循环 + 时钟中断 来不断调用系统的任务的。

1. 系统调用的作用

  • 桥梁作用:允许用户程序请求内核执行特权操作(如文件操作、进程管理、网络通信等)。

  • 安全隔离:用户程序无法直接访问硬件或内核资源,必须通过系统调用委托内核完成,确保系统安全和稳定。

2. 系统调用的触发方式

  • 软中断或专用指令

    • 传统方式:通过int 0x80(x86)触发软中断。

    • 现代方式:使用更高效的syscall/sysenter指令(x86_64)或svc(ARM)。

  • 内核入口:触发后,CPU切换到内核态,跳转到预设的中断处理程序(如entry_SYSCALL_64)。

3. 系统调用的执行流程

         1.OS在启动时,会初始化一张函数指针数组,这个函数指针数组就是系统调用表(sys_call_table),OS要调用系统调用,只需要找到特定的函数指针数组下标,就能执行对应的系统调用。

        2.在OS的中断向量表中,同样有“执行任意系统调用”的方法。

实例:

        1.在调用fork()「父进程创建一个子进程」的时候,OS会把sys_fork的系统调用号存入寄存器,同时向CPU执行进入系统的(int ox80)中断,于是CPU据此形成中断号,并根据中断号索引到“执行任意系统调用”的方法。然后传入系统调用号,在sys_call_table中索引执行系统调用。

 已知OS不相信任何用户,OS如何做到阻止用户直接访问内核空间?

        1、CPU中有一个特殊的寄存器CS(Code Semgment)寄存器,这个寄存器存储的是当前执行的代码的地址范围。寄存器的低二位的状态则代表了当前OS所处的状态:

        如果低二位为0——内核态

        如果低二位为3——用户态

总结:

        对用户空间,CPU会根据得到的虚拟地址通过页表转换访问物理地址。当CPU拿到的虚拟地址是[3,4]GB的内核空间的时候,CPU会检测到CS寄存器低二位是否是0(内核态),如果不是,则CPU拦截非法访问,如果是,则可以访问内核空间数据。


完~

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Windows中使用Docker安装Anythingllm,基于deepseek构建自己的本地知识库问答大模型,可局域网内多用户访问、离线运行

文章目录 Windows中使用Docker安装Anythingllm,基于deepseek构建自己的知识库问答大模型1. 安装 Docker Desktop2. 使用Docker拉取Anythingllm镜像2. 设置 STORAGE_LOCATION 路径3. 创建存储目录和 .env 文件.env 文件的作用关键配置项 4. 运行 Docker 命令docker r…

w~自动驾驶~合集17

我自己的原文哦~ https://blog.51cto.com/whaosoft/13269720 #FastOcc 推理更快、部署友好Occ算法来啦! 在自动驾驶系统当中,感知任务是整个自驾系统中至关重要的组成部分。感知任务的主要目标是使自动驾驶车辆能够理解和感知周围的环境元素&#…

利用邮件合并将Excel的信息转为Word(单个测试用例转Word)

利用邮件合并将Excel的信息转为Word 效果一览效果前效果后 场景及问题解决方案 一、准备工作准备Excel数据源准备Word模板 二、邮件合并操作步骤连接Excel数据源插入合并域预览并生成合并文档 效果一览 效果前 效果后 场景及问题 在执行项目时的验收阶段,对于测试…

2024 CyberHost 语音+图像-视频

项目:CyberHost: Taming Audio-driven Avatar Diffusion Model with Region Codebook Attention 音频驱动的身体动画面临两个主要挑战:(1)关键人体部位,如面部和手部,在视频帧中所占比例较小&#x…

web前端第三次作业

题目 本期作业 WEB第三次作业 请使用JS实一个网页中登录窗口的显示/隐藏&#xff0c;页面中拖动移动&#xff0c;并且添加了边界判断的网页效 代码图片 效果展示 代码 <!DOCTYPE html> <html lang"zh"> <head> <meta charset"UTF-8&qu…

国产ARM处理器工控机如何助力企业实现自主可控?

选择国产ARM处理器工控机的原因可以从多个角度来考虑&#xff0c;包括技术、经济、安全和政策等方面。以下是一些关键理由&#xff1a; 技术优势 低功耗高效能&#xff1a;ARM架构以其出色的能效比著称&#xff0c;适合需要长时间运行的工业控制应用。适应性强&#xff1a;国…

力扣24题——两两交换链表中节点

#题目 #代码 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val) { this.val val; }* ListNode(int val, ListNode next) { this.val val; this.next next; }* }*/ clas…

DedeBIZ系统审计小结

之前简单审计过DedeBIZ系统&#xff0c;网上还没有对这个系统的漏洞有过详尽的分析&#xff0c;于是重新审计并总结文章&#xff0c;记录下自己审计的过程。 https://github.com/DedeBIZ/DedeV6/archive/refs/tags/6.2.10.zip &#x1f4cc;DedeBIZ 系统并非基于 MVC 框架&…

leetocde92:翻转链表II

前文关于反转链表的解析https://blog.csdn.net/weixin_46028606/article/details/145592860?fromshareblogdetail&sharetypeblogdetail&sharerId145592860&sharereferPC&sharesourceweixin_46028606&sharefromfrom_link 翻转链表II 代码一定要结合下面的图…

考研操作系统----操作系统的概念定义功能和目标(仅仅作为王道哔站课程讲义作用)

目录 操作系统的概念定义功能和目标 操作系统的四个特征 操作系统的分类 ​编辑 操作系统的运行机制 系统调用 操作系统体系结构 操作系统引导 虚拟机 操作系统的概念定义功能和目标 什么是操作系统&#xff1a; 操作系统是指控制和管理整个计算机系统的软硬件资源&…

【WB 深度学习实验管理】使用 PyTorch Lightning 实现高效的图像分类实验跟踪

本文使用到的 Jupyter Notebook 可在GitHub仓库002文件夹找到&#xff0c;别忘了给仓库点个小心心~~~ https://github.com/LFF8888/FF-Studio-Resources 在机器学习项目中&#xff0c;实验跟踪和结果可视化是至关重要的环节。无论是调整超参数、优化模型架构&#xff0c;还是监…

异位妊娠唯一相关的是年龄(U型曲线)

异位妊娠唯一相关的是年龄&#xff08;U型曲线&#xff09; 简介 异位妊娠&#xff0c;俗称宫外孕&#xff0c;是指受精卵在子宫体腔以外着床发育的异常妊娠过程 。正常情况下&#xff0c;受精卵会在子宫内着床并发育成胎儿&#xff0c;但在异位妊娠中&#xff0c;受精卵却在…

ESM3(1)-介绍:用语言模型模拟5亿年的进化历程

超过30亿年的进化在天然蛋白质空间中编码形成了一幅生物学图景。在此&#xff0c;作者证明在进化数据上进行大规模训练的语言模型&#xff0c;能够生成与已知蛋白质差异巨大的功能性蛋白质&#xff0c;并推出了ESM3&#xff0c;这是一款前沿的多模态生成式语言模型&#xff0c;…

CondaValueError: Malformed version string ‘~‘: invalid character(s)

CondaValueError: Malformed version string ‘~‘: invalid character(s) 送一张 GPT plus 、 deepseek-R1 满血 体验卡&#xff5e; https://bbs.csdn.net/topics/619568415 ​ 报错原因 使用conda安装一些库时出现以下报错&#xff1a; CondaValueError: Malformed versio…

01、单片机上电后没有正常运行怎么办

单片机上电后没有运转, 首先要检查什么? 1、单片机供电是否正常? &电路焊接检查 如果连最基本的供电都没有,其它都是空谈啊!检查电路断路了没有?短路了没有?电源合适吗?有没有虚焊? 拿起万用表之前,预想一下测量哪里?供电电压应该是多少?对PCB上电压测量点要…

基于Java的分布式系统架构设计与实现

Java在大数据处理中的应用&#xff1a;基于Java的分布式系统架构设计与实现 随着大数据时代的到来&#xff0c;数据处理的规模和复杂性不断增加。为了高效处理海量数据&#xff0c;分布式系统成为了必不可少的架构之一。而Java&#xff0c;凭借其平台独立性、丰富的生态系统以…

【含文档+PPT+源码】基于Python的全国景区数据分析以及可视化实现

项目介绍 本课程演示的是一款基于Python的全国景区数据分析以及可视化实现&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的 Java 学习者。 包含&#xff1a;项目源码、项目文档、数据库脚本、软件工具等所有资料 带你从零开始部署运行本套系统 该…

Apache Kafka 中的认证、鉴权原理与应用

编辑导读&#xff1a;本篇内容将进一步介绍 Kafka 中的认证、鉴权等概念。AutoMQ 是与 Apache Kafka 100% 完全兼容的新一代 Kafka&#xff0c;可以帮助用户降低 90%以上的 Kafka 成本并且进行极速地自动弹性。作为 Kafka 生态的忠实拥护者&#xff0c;我们也会持续致力于传播 …

初阶数据结构:树---二叉树的链式结构

目录 一、二叉树的链式结构 &#xff08;一&#xff09;、概念 二、二叉树链式结构的实现 &#xff08;一&#xff09;、二叉树链式结构的遍历 1、前序遍历 2、中序遍历 3、后序遍历 4、层序遍历 &#xff08;二&#xff09;、二叉树的构建 &#xff08;三&#xff0…

SurfGen爬虫:解析HTML与提取关键数据

一、SurfGen爬虫框架简介 SurfGen是一个基于Swift语言开发的爬虫框架&#xff0c;它提供了丰富的功能&#xff0c;包括网络请求、HTML解析、数据提取等。SurfGen的核心优势在于其简洁易用的API和高效的性能&#xff0c;使得开发者能够快速构建爬虫程序。以下是SurfGen的主要特…