一篇文章全面了解Linux进程调度 1周前查看 评论
一篇文章全面了解Linux进程调度

进程调度是确保进程能有效工作的一个内核子系统,决定哪个进程可以投入运行,可以运行多长时间。进程和线程在创建到销毁的过程中,会经历创建、就绪、执行、阻塞、终止五种状态的转换。多任务操作系统可以分为非抢占式和抢占式两种,其中抢占式操作系统可以让多个进程处于阻塞或者睡眠状态,这些进程不会真正运行,直到等待的条件(例如键盘输入、网络数据到达、定时器)就绪。进程相关的数据结构主要包括task_struct,进程状态、pid和tgid、进程内核栈、进程标记、进程的父子、兄弟关系等。内核线程是直接由内核本身启动的进程,用于执行周期性的任务。调度器的实现基于周期性调度器函数和主调度器函数,其中周期性调度器函数负责管理内核中与整个系统和各个进程的调度相关的统计量,而主调度器函数则负责执行调度过程。Linux进程调度机制的历史经历了从Linux1.0到2.6的演变,引入了O(1)调度器和完全公平调度算法(CFS)。进程调度策略需要在响应时间和吞吐量之间寻求平衡,Linux更加倾向于优先调度I/O消耗型进程,以缩短响应时间。进程按优先级可分为硬实时进程、软实时进程、普通进程,Linux采用了两种不同的优先级范围:nice值和实时优先级。时间片是一个数值,用来表示进程被抢占前,能够持续运行的时间。调度器类是Linux以模块的方式提供的调度器,以便不同类型的进程可以选择不同的调度算法。目前Linux提供了以下调度器类:完全公平调度器类(CFS)、实时调度器类(RT)和Deadline调度器。完全公平调度类(CFS)使用红黑树来组织可运行进程队列,排序依据为虚拟运行时间vruntime。实时调度类(RT)按照POSIX标准的强制要求,除了“普通”进程之外,Linux还支持两种实时调度器类,分别是循环进程(SCHED_RR)和先进先出进程(SCHED_FIFO)。

任务调度器:从入门到放弃(二) 1周前查看 评论
任务调度器:从入门到放弃(二)

本文讨论了理想调度模型与实际工程实现之间的差异,分析了Linux调度器中的事件驱动机制及其带来的不确定性。文中介绍了任务调度器的两个关键指标:吞吐量(throughout)和调度精度(latency)。同时,针对big-little架构,探讨了如何界定任务的大小以及如何在不同核心之间分配任务以达到性能与功耗的平衡。文中还对比了两种负载量化模型:PELT和WALT,并讨论了它们在处理任务负载变化时的局限性。

任务调度器:从入门到放弃(一) 1月前查看 评论
任务调度器:从入门到放弃(一)

本文是关于Linux内核调度器的科普文章,作者XiaoGang通过内部项目复盘中的实际问题,引出了调度器的重要性和工作原理。文章主要内容包括: 1. 调度器的作用:CPU资源有限,但任务数量众多,调度器通过分时复用让用户感觉多个线程同时运行。 2. Linux的调度类:包括stop、deadline、realtime、fair和idle等,各有不同的优先级。 3. RT调度类与fair调度的区别:RT调度类按照优先级顺序选择任务,而fair调度类采用虚拟运行时间(virtual runtime)来决定任务的调度。 4. 调度器管理的任务:只有处于TASK_RUNNING状态的进程在调度器的管理范围内。 5. 比例调度的问题:通过大量低优先级线程可能占用较高资源配额。 6. cgroup的作用和问题:cgroup通过cpu.shares控制资源配额,解决比例调度问题,但同时也带来了一些新的挑战。 文章以实例和实验说明问题,深入浅出地解释了调度器的复杂机制。下周将更新续篇,继续探讨相关话题。

[Android稳定性] 第036篇 [原理篇] 理解中断上下文、进程上下文以及进程调度之间的关系 3月前查看 评论
[Android稳定性] 第036篇 [原理篇] 理解中断上下文、进程上下文以及进程调度之间的关系

一、三者概念的梳理 1.1 进程上下文(Process Context) 当内核代码是在为一个具体进程执行某项任务(比如响应系统调用)时,就是在“进程上下文”。 是普通用户或内核线程运行的上下文。 可以被调度、休眠、阻塞。 拥有完整的进程信息(task_struct)。 可以执行阻塞操作,比如 sl