[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拦截非法访问,如果是,则可以访问内核空间数据。


完~

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2025.2.11

1> 制作一个闹钟软件 .h #ifndef WIDGET_H #define WIDGET_H#include <QWidget> #include <QLabel> #include <QLineEdit> #include <QPushButton> #include <QTime> #include <QTimer> #include <QTimeEdit> #include <QDa…

和鲸科技上线 DeepSeek 系列模型服务,助力数智企业 AI 业务创新!

近日&#xff0c;和鲸科技团队宣布旗下数据科学协同平台 ModelWhale 实现对 DeepSeek 全系列大模型的深度支持&#xff0c;旨在帮助更多数智化转型企业提供从算力基建到业务融合的全栈式解决方案&#xff0c;快速搭建自主可控的云端智能服务体系&#xff0c;实现大模型与业务系…

使用亚马逊针对 PyTorch 和 MinIO 的 S3 连接器进行模型检查点处理

2023 年 11 月&#xff0c;Amazon 宣布推出适用于 PyTorch 的 S3 连接器。适用于 PyTorch 的 Amazon S3 连接器提供了专为 S3 对象存储构建的 PyTorch 数据集基元&#xff08;数据集和数据加载器&#xff09;的实现。它支持用于随机数据访问模式的地图样式数据集和用于流式处理…

基于 SpringBoot 和 Vue 的智能腰带健康监测数据可视化平台开发(文末联系,整套资料提供)

基于 SpringBoot 和 Vue 的智能腰带健康监测数据可视化平台开发 一、系统介绍 随着人们生活水平的提高和健康意识的增强&#xff0c;智能健康监测设备越来越受到关注。智能腰带作为一种新型的健康监测设备&#xff0c;能够实时采集用户的腰部健康数据&#xff0c;如姿势、运动…

【cocos creator】拖拽排序列表

DEMO下载 GameCtrl.ts import ItemCtrl from "./ItemCtrl";const { ccclass, property } cc._decorator;ccclass export default class GameCtrl extends cc.Component {property(cc.Node)content: cc.Node null;property(cc.Node)prefab: cc.Node null;arr []…

Vision Transformer:打破CNN垄断,全局注意力机制重塑计算机视觉范式

目录 引言 一、ViT模型的起源和历史 二、什么是ViT&#xff1f; 图像处理流程 图像切分 展平与线性映射 位置编码 Transformer编码器 分类头&#xff08;Classification Head&#xff09; 自注意力机制 注意力图 三、Coovally AI模型训练与应用平台 四、ViT与图像…

国产编辑器EverEdit - 编辑辅助功能介绍

1 编辑辅助功能 1.1 各编辑辅助选项说明 1.1.1 行号 打开该选项时&#xff0c;在编辑器主窗口左侧显示行号&#xff0c;如下图所示&#xff1a; 1.1.2 文档地图 打开该选项时&#xff0c;在编辑器主窗口右侧靠近垂直滚动条的地方显示代码的缩略图&#xff0c;如下图所示&…

Spring AI 介绍

文章来源&#xff1a;AI 概念 (AI Concepts) _ Spring AI1.0.0-SNAPSHOT中文文档(官方文档中文翻译)|Spring 教程 —— CADN开发者文档中心 本节介绍 Spring AI 使用的核心概念。我们建议仔细阅读它&#xff0c;以了解 Spring AI 是如何实现的。 模型 AI 模型是旨在处理和生成…

Spring MVC 拦截器(Interceptor)与过滤器(Filter)的区别?

1、两者概述 拦截器&#xff08;Interceptor&#xff09;&#xff1a; 只会拦截那些被 Controller 或 RestController 标注的类中的方法处理的请求&#xff0c;也就是那些由 Spring MVC 调度的请求。过滤器&#xff08;Filter&#xff09;&#xff1a; 会拦截所有类型的 HTTP …

qt QCommandLineOption 详解

1、概述 QCommandLineOption类是Qt框架中用于解析命令行参数的类。它提供了一种方便的方式来定义和解析命令行选项&#xff0c;并且可以与QCommandLineParser类一起使用&#xff0c;以便在应用程序中轻松处理命令行参数。通过QCommandLineOption类&#xff0c;开发者可以更便捷…

Flink KafkaConsumer offset是如何提交的

一、fllink 内部配置 client.id.prefix&#xff0c;指定用于 Kafka Consumer 的客户端 ID 前缀partition.discovery.interval.ms&#xff0c;定义 Kafka Source 检查新分区的时间间隔。 请参阅下面的动态分区检查一节register.consumer.metrics 指定是否在 Flink 中注册 Kafka…

从Word里面用VBA调用NVIDIA的免费DeepSeekR1

看上去能用而已。 选中的文字作为输入&#xff0c;运行对应的宏即可&#xff1b;会先MSGBOX提示一下&#xff0c;然后相关内容追加到word文档中。 需要自己注册生成好用的apikey Option ExplicitSub DeepSeek()Dim selectedText As StringDim apiKey As StringDim response A…

网络工程师 (29)CSMA/CD协议

前言 CSMA/CD协议&#xff0c;即载波监听多路访问/碰撞检测&#xff08;Carrier Sense Multiple Access with Collision Detection&#xff09;协议&#xff0c;是一种在计算机网络中&#xff0c;特别是在以太网环境下&#xff0c;用于管理多个设备共享同一物理传输介质的重要…

WPS中如何批量上下居中对齐word表格中的所有文字

大家好&#xff0c;我是小鱼。 在日常制作Word表格时&#xff0c;经常需要对表格中的内容进行排版。经常会把文字设置成左对齐、居中对齐或者是右对齐&#xff0c;这些对齐方式都比较好设置&#xff0c;有时制作的表格需要把文字批量上下居中对齐&#xff0c;轻松几步就可以搞…

GeekPad智慧屏编程控制

前面通过homeassistant和emqx一番折腾&#xff0c;已经可以控制GeekPad智慧屏的开关了。但是这中间用到的软件对环境依赖非常高&#xff0c;想再优化一下&#xff0c;把这两个工具都装到手机上&#xff0c;最后勉强实现了&#xff0c;但是还得借用模拟器和容器&#xff0c;稳定…

【DeepSeek】在本地计算机上部署DeepSeek-R1大模型实战(完整版)

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈人工智能与大模型应用 ⌋ ⌋ ⌋ 人工智能&#xff08;AI&#xff09;通过算法模拟人类智能&#xff0c;利用机器学习、深度学习等技术驱动医疗、金融等领域的智能化。大模型是千亿参数的深度神经网络&#xff08;如ChatGPT&…

可编程网卡芯片在京东云网络的应用实践【BGW边界网关篇】

目录导览 文章背景 一.网关问题分析 BGW专线网关机器运维变更困难 BGW专线网关故障收敛链路复杂且长 BGW专线网关不具备异构架构下的灾备能力 BGW专线网关硬件资源成本居高不下 二.技术方案设计实现 网络拓扑规划与VIP架构升级 硬件实现与N-Tb流量平滑迁移 三.落地…

接口测试Day12-持续集成、git简介和安装、Gitee远程仓库、jenkins集成

持续集成 概念&#xff1a; 团队成员将自己的工作成果&#xff0c;持续集成到一个公共平台的过程。成员可以每天集成一次&#xff0c;也可以一天集成多 次。 相关工具&#xff1a; 本地代码管理&#xff1a;git远程代码管理&#xff1a;gitee(国内)、github(国外)、gitlib(公司…

前端快速生成接口方法

大家好&#xff0c;我是苏麟&#xff0c;今天聊一下OpenApi。 官网 &#xff1a; umijs/openapi - npm 安装命令 npm i --save-dev umijs/openapi 在根目录&#xff08;项目目录下&#xff09;创建文件 openapi.config.js import { generateService } from umijs/openapi// 自…

三角测量——用相机运动估计特征点的空间位置

引入 使用对极约束估计了相机运动后&#xff0c;接下来利用相机运动估计特征点的空间位置&#xff0c;使用的方法就是三角测量。 三角测量 和对极几何中的对极几何约束描述类似&#xff1a; z 2 x 2 R ( z 1 x 1 ) t z_2x_2R(z_1x_1)t z2​x2​R(z1​x1​)t 经过对极约束…