Linux 下常见的进程调度算法

在操作系统中资源是有限的,当有多个进程或线程要使用这些资源时,因为资源的有限性,必须按照一定的原则选择进程来使用资源。
所以调度算法就是 :根据系统的资源分配策略所规定的资源分配算法。
调度算法要求 :高资源利用率,高吞吐量,用户满意等原则。
调度算法设计目标:
1. 批处理系统
增加系统吞吐量和提高系统资源利用率。
2. 分时系统
保证每个分时用户能容忍的响应时间。
3. 实时系统
保证对随机发生的外部时间做出实时相应。

常见调度算法:

1. 先来先服务(FCFS)

  1. FCFS 算法
    按照作业提交或进程变为就绪态的先后次序,分配 CPU。当前作业或进程占用 CPU ,直到执行完或阻塞,才让出 CPU。在作业或进程唤醒后并不立即恢复执行,通常等到当前作业或进程让出 CPU。
  2. 特点
    有利于长作业,不利于短作业。有利于 CPU 繁忙的作业,而不利于 I/O 繁忙的作业。


2. 短作业(进程)优先调度算法SJ(P)F

  1. 概念
    对预计执行时间短的作业/进程优先分派处理。通常后来的短作业不抢先正在进行的作业。
  2. 优点
    比FCFS改善平均周转时间和平均带权周转时间,缩短作业的等待时间;
    提高系统吞吐量。
  3. 缺点
    对长作业不利,可能长时间得不到执行。
    未能根据作业的紧迫程度设置优先级。
    难以准确估计作业的执行时间,从而影响调度性能。


3. 轮转算法

  1. 概念
    让每个进程在就绪队列中的等待时间与享受服务的时间成正比。
  2. 定义
    系统把所有就绪态进程按先入先出的原则排成一个队列。新来的进程加到就绪队列的末尾。每当执行调度时,进程调度程序总是选出就绪队列的队首进程,让它在 CPU 上运行一个时间片的时间。当进程用完分给它的时间片时,调度程序停止该进程的运行,并将其添加到就绪队列末尾。
    进程可以未使用完一个时间片就让出 CPU。
    就绪进程数目越多,时间片越小。
  3. 缺点
    当时间片过长时,将退化为FCFS算法,进程在一个时间片内都执行完,响应时间过长。
    当时间片过短时,用户的一次请求需要多个时间片才能处理完,上下文切换次数增加,响应时间长。


4. 多级反馈队列算法

  1. 概念
    多级反馈队列算法是时间轮片算法和优先级算法的综合发展。
  2. 定义
    设置多个就绪队列,分别赋予不同的优先级。如逐级降低,队列1优先级最高。
    每个优先级队列的执行时间也不同,规定优先级越低时间片越长。
    新进程进入内存后,先投入队列1的末尾,按FCFS算法调度;若按队列1一个时间片未能执行完,则降低投入到队列2的末尾,同样按FCFS算法调度;如此下去,降低到最后的队列,则按“时间片轮转”算法调度直到完成。
    仅当较高优先级的队列为空,才调度较低优先级的队列中的进程执行。如果进程执行时有新进程进入较高优先级的队列,则抢先执行新进程,并把被抢先的进程投入原队列的末尾。
  3. 优点
    提高了系统吞吐量和缩短平均周转时间而照顾短进程。
    获得较好的 I/O 设备利用率和缩短响应时间而照顾 I/O 型进程。
    不必估计进程的执行时间,动态调节。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux模拟进程调度算法是指在Linux操作系统中,通过模拟不同的进程调度算法来实现进程调度常见进程调度算法包括先来先服务(FCFS)、短作业优先(SJF)、优先级调度、时间片轮转等。在Linux中,通过调整进程的优先级、时间片大小等参数来模拟不同的进程调度算法,以达到更好的系统性能和用户体验。 ### 回答2: Linux是一个开源的操作系统,因为其稳定性、安全性和高效性,已成为世界上最受欢迎的操作系统之一。 在Linux中,进程是分时的,这意味着系统在不同的进程之间进行切换,以实现并发性。 这种进程调度算法称为模拟进程调度算法,它的方式类似于每个进程都有它自己的CPU,但实际上只有一个CPU并且都在共享它。 在Linux中,进程调度系统在内核高速缓存中维护一个就绪队列。 在就绪队列中,所有就绪状态的进程都排队等待被CPU执行。 当一个进程等待IO操作完成时,它的状态被改为就绪状态,并放回到就绪队列的末尾。 然后,调度程序检查就绪队列,并根据当前的调度算法选择下一个要执行的进程Linux使用许多不同的进程调度算法。其中最常见的是时间片轮转算法。 在时间片轮转算法中,每个进程都被分配一个固定的时间片,例如50毫秒。 当进程的时间片用完时,进程的状态被改为就绪状态并重新排队。 如果进程需要的时间片超过了分配给它的时间,就会执行抢占,调度程序会立即中断当前进程并选择下一个进程。 另一种常见调度算法是优先级调度算法。 在优先级调度算法中,调度程序为每个进程分配一个优先级,然后选择具有最高优先级的进程以执行。 如果几个进程具有相同的优先级,则调度程序使用时间片轮转算法来选择下一个进程。 另一种调度算法是最短作业优先算法。 在这种情况下,调度程序选择要执行的长度最短的进程。这通常用于批处理系统,其中有许多批量作业需要在固定的时间内完成。 总之,Linux支持多种不同的进程调度算法,以满足各种系统的需求。这些算法基于任务时间片,进程优先级和执行时间的不同原则,合理地分配资源和优化系统性能,使Linux系统的管理更高效、更有效、更灵活。 ### 回答3: Linux操作系统使用CFS(Completely Fair Scheduler,完全公平调度器)算法来模拟进程调度。CFS是一种基于红黑树的调度算法,其核心思想是让所有进程都能够“公平”地获得CPU资源。 红黑树是一种自平衡二叉查找树,Linux CFS使用红黑树来存储可运行进程的任务队列,这些任务队列是按照进程优先级、CPU时间片长度和进程运行情况等因素排序的。 CFS将所有可运行进程视为一个整体,每个进程拥有一定的虚拟CPU时间片,进程的优先级和进程的优先级调整都会影响进程获得CPU时间片的权重。 在CFS中,权重是动态计算的,与进程使用CPU的时间成反比。即当进程使用CPU时间少时,其获得CPU时间片的权重会增加,下一次获得CPU时间片的几率也会增加;反之,如果进程使用CPU时间较多,其权重会降低,CPU时间片的几率也会降低。这样,CFS可以保证所有进程获得公平的CPU时间片。 此外,CFS还支持优先级反转,即在两个进程优先级相差较大,但优先级较低的进程持续占用CPU资源时,CFS会降低该进程的权重,使优先级较高的进程优先获得CPU时间片。 总的来说,CFS算法是一种非常高效、公平和可靠的调度算法,可以有效地提高Linux系统的CPU利用率和运行效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值