Linux内核的进程调度与定时器实现 (linux内核进程调度以及定时器实现机制)

Linux内核是一个经典的操作系统,它无处不在,每天都在我们身边,为我们的生活提供着可靠的保证。在这个操作系统中,关于进程调度与定时器的实现是非常关键的一部分。本文将重点介绍。

一、进程调度

进程调度是指为了保证系统的高效运行,将CPU时间片分配给不同的进程以供其运行的过程。在许多操作系统中,进程调度都是以时间片轮转为基础的,也就是在一段时间内,每个进程都能够平均地获得CPU时间片,而在Linux内核中,采用的是基于优先级的时间片轮转算法。

在Linux内核中,进程的优先级可以分为两类:实时进程和非实时进程。实时进程是指要求立即响应的进程,比如说实时视频等,而非实时进程则是普通的进程,比如查看文件等。因此,实时进程的优先级比非实时进程的优先级高。

在进程调度中,Linux内核采用了“完全公平调度器”(Completely Fr Scheduler)来保证公平性。这个调度器将每个进程都看做是一个运行周期的一部分,而每个进程运行所花费的时间则取决于进程的nice值,这个值越小,进程的优先级越高。同时,Linux内核还设置了一个调度策略,用于在不同的负载条件下优化进程调度。

二、定时器实现

在Linux内核中,定时器是一个非常重要的概念。定时器可以用于延迟执行某些代码或者周期性地执行某些代码。在Linux内核中,定时器的实现方式可以分为两种:硬件定时器和软件定时器。

硬件定时器的核心是计时器,它可以通过特殊的硬件插件来实现,例如芯片、声卡等。硬件定时器在系统中的延迟非常小,可以借助CPU的时钟来完成,定时器的精度非常高。但是,硬件定时器的实现需要硬件支持,所以它的可移植性非常差。

软件定时器则是指由操作系统内核提供的定时功能。软件定时器不需要特殊的硬件支持,因此其可移植性非常好。Linux内核中,软件定时器是由内核代码实现的,可以在任何平台上使用。

在Linux内核中,定时器的实现原理是使用了内核中的工作队列方法。这个方法可以在指定的时间间隔内执行指定的工作任务,这个任务可以是等待、唤醒、延迟等操作。工作队列还可以根据不同的策略实现优化,例如睡眠等待策略、分隔策略等。

三、

进程调度和定时器是操作系统中非常重要的部分。在Linux内核中,进程调度通过时间片轮转算法和完全公平调度器来实现,同时根据负载条件自动调节调度策略。定时器的实现则是通过工作队列的方式来完成,并且可以利用不同的策略实现优化,保证系统的稳定性和高效性。了解进程调度和定时器的实现原理对于理解操作系统的基本原理非常有帮助。

相关问题拓展阅读:

  • linux进程、线程及调度算法(三)

linux进程、线程及调度算法(三)

调度策略值得是大家都在ready时,并且CPU已经被调度时,决定谁来运行,谁来被调度。

两者之间有一定矛盾。

响应的优化,意味着高优先级会抢占优先级,会花时间在上下文切换,会影响吞吐。

上下文切换的时间是很短的,几微妙就能搞定。上下文切换本身对吞吐并多大影响,

重要的是,切换后引起的cpu 的 cache miss.

每次切换APP, 数据都要重新load一次。

Linux 会尽可能的在响应与吞吐之间寻找平衡。比如在编译linux的时候,会让你选择 kernal features -> Preemption model.

抢占模型会影响linux的调度算法。

所以 ARM 的架构都是big+LITTLE, 一个很猛CPU+ 多个 性能较差的 CPU, 那么可以把I/O型任务的调度指源 放在 LITTLE CPU上。需要计算的放在big上。

早期2.6 内核将优先级划分了bit的优先级。数值越低,优先级越高。0-99优先级 都是 RT(即时响应)的 ,都是非RT的,即normal。

调度的时候 看哪个bitmap 中的 优先级上有任务ready。可能多个任务哦。

在普通优先级线程调度中,高优先级并不代表对低优先级的绝对优势。会在不同优先级进行轮转。

就是比101高,101也会比102高,但100 不会堵着101。

众丝进程在轮转时,优先级高的:

初始唯并态设置nice值为0,linux 会探测 你是喜欢睡眠,还是干活。越喜欢睡,linux 越奖励你,优先级上升(nice值减少)。越喜欢干活,优先级下降(nice值增加)。所以一个进程在linux中,干着干着 优先级越低,睡着睡着 优先级越高。

后期linux补丁中

红黑树,数据结构, 左边节点小于右边节点

同时兼顾了 CPU/IO 和 nice。

数值代表着 进程运行到目前为止的virtual runtime 时间。

(pyhsical runtime) / weight * 1024(系数)。

优先调度 节点值(vruntime)最小的线程。权重weight 其实有nice 来控制。

一个线程一旦被调度到,则物理运行时间增加,vruntime增加,往左边走。

weight的增加,也导致vruntime减小,往右边走。

总之 CFS让线程 从左滚到右,从右滚到左。即照顾了I/O(喜欢睡,分子小) 也 照顾了 nice值低(分母高).所以 由喜欢睡,nice值又低的线程,最容易被调度到。

自动调整,无需向nice一样做出奖励惩罚动作,个人理解权重其实相当于nice

但是 此时 来蔽拍一个 0-99的线程,进行RT调度,都可以瞬间秒杀你!因为人家不是普通的,是RT的!

一个多线程的进程中,每个线程的调度的策略 如 fifo rr normal, 都可以不同。每一个的优先级都可以不一样。

实验举例, 创建2个线程,同时开2个:

运行2次,创建两个进程

sudo renice -n -5(nice -5级别) -g(global), 会明显看到 一个进程的CPU占用率是另一个的 3倍。

为什么cpu都已经达到200%,为什么系统不觉得卡呢?因为,我们的线程在未设置优先级时,是normal调度模式,且是

CPU消耗型

调度级别其实不高。

利用chrt工具,可以将进程 调整为 50 从normal的调度策略 升为RT (fifo)级别的调度策略,会出现:

chrt , nice renice 的调度策略 都是以线程为单位的,以上 设置的将进程下的所有线程进行设置nice值

线程是调度单位,进程不是,进程是资源封装单位!

两个同样死循环的normal优先级线程,其中一个nice值降低,该线程的CPU 利用率就会比另一个CPU的利用率高。

linux内核进程调度以及定时器实现机制的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于linux内核进程调度以及定时器实现机制,Linux内核的进程调度与定时器实现,linux进程、线程及调度算法(三)的信息别忘了在本站进行查找喔。

香港服务器首选树叶云,2H2G首月10元开通。
树叶云(shuyeidc.com)提供简单好用,价格厚道的香港/美国云服务器和独立服务器。IDC+ISP+ICP资质。ARIN和APNIC会员。成熟技术团队15年行业经验。

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/192645.html<

(0)
运维的头像运维
上一篇2025-04-01 16:41
下一篇 2025-04-01 16:43

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注