1。SCHED_OTHER 分时调度策略;

2。SCHED_FIFO 实时调度策略。先到先服务;

3,SCHED_RR 实时调度策略,时间片轮转 。

实时进程将得到优先调用,实时进程依据实时优先级决定调度权值,分时进程则通过nice和counter值决定权值,nice越小,counter越大,被调度的概率越大。也就是以前使用了 cpu 最少的进程将会得到优先调度。

SHCED_RR 和 SCHED_FIFO 的不同:

当採用 SHCED_RR 策略的进程的时间片用完,系统将又一次分配时间片。并置于就绪队列尾。放在队列尾保证了全部具有同样优先级的RR任务的调度公平。

SCHED_FIFO 一旦占用 cpu 则一直执行。一直执行直到有更高优先级任务到达或自己放弃。

假设有同样优先级的实时进程(依据优先级计算的调度权值是一样的)已经准备好,FIFO时必须等待该进程主动放弃后才干够执行这个优先级同样的任务。

而RR能够让每一个任务都执行一段时间。

同样点:

RR 和 FIFO 都仅仅用于实时任务。

创建时优先级大于0(1-99)。

依照可抢占优先级调度算法进行。

就绪态的实时任务马上抢占非实时任务。

全部任务都採用Linux分时调度策略时,

1,创建任务指定採用分时调度策略。并指定优先级nice值(-20~19)。

2,将依据每一个任务的nice值确定在cpu上的运行时间(counter)。

3。假设没有等待资源,则将该任务增加到就绪队列中。

4。调度程序遍历就绪队列中的任务。通过对每一个任务动态优先级的计算(counter+20-nice)结果。选择计算结果最大的一个去执行,当这 个时间片用完后(counter减至0)或者主动放弃cpu时。该任务将被放在就绪队列末尾(时间片用完)或等待队列(因等待资源而放弃cpu)中。

5,此时调度程序反复上面计算过程,转到第4步。

6。当调度程序发现全部就绪任务计算所得的权值都为不大于0时,反复第2步。

全部任务都採用 FIFO 时

1。创建进程时指定採用 FIFO,并设置实时优先级 rt_priority(1-99)。

2,假设没有等待资源,则将该任务增加到就绪队列中。

3。调度程序遍历就绪队列。依据实时优先级计算调度权值(1000+rt_priority),选择权值最高的任务使用 cpu,该 FIFO 任务将一直占有 cpu 直到有优先级更高的任务就绪(即使优先级同样也不行)或者主动放弃(等待资源)。

4,调度程序发现有优先级更高的任务到达(高优先级任务可能被中断或定时器任务唤醒。再或被当前执行的任务唤醒,等等)。则调度程序马上在当前任务 堆栈中保存当前cpu寄存器的全部数据。又一次从高优先级任务的堆栈中载入寄存器数据到cpu。此时高优先级的任务開始执行。

反复第3步。

5,假设当前任务因等待资源而主动放弃cpu使用权。则该任务将从就绪队列中删除。增加等待队列。此时反复第3步。

全部任务都採用RR调度策略时

1。创建任务时指定调度參数为 RR,并设置任务的实时优先级和nice值(nice值将会转换为该任务的时间片的长度)。

2。假设没有等待资源。则将该任务增加到就绪队列中。

3,调度程序遍历就绪队列。依据实时优先级计算调度权值 (1000+rt_priority) ,选择权值最高的任务使用 cpu。

4,假设就绪队列中的 RR 任务时间片为0。则会依据 nice 值设置该任务的时间片,同一时候将该任务放入就绪队列的末尾。反复步骤3。

5,当前任务因为等待资源而主动退出 cpu,则其增加等待队列中。

反复步骤3。

系统中既有分时调度,又有时间片轮转调度和先进先出调度时

1,RR 调度和 FIFO 调度的进程属于实时进程,以分时调度的进程是非实时进程。

2。当实时进程准备就绪后,假设当前 cpu 正在执行非实时进程,则实时进程马上抢占非实时进程。

3。RR 进程和 FIFO 进程都採用实时优先级做为调度的权值标准,RR是FIFO的一个延伸。FIFO时,假设两个进程的优先级一样,则这两个优先 级一样的进程详细运行哪一个是由其在队列中的位置决定的,这样导致一些不公正性(优先级是一样的。为什么要让你一直运行?),假设将两个优先级一样的任务 的调度策略都设为RR,则保证了这两个任务能够循环运行,保证了公平。

操作系统 linux 内核的三种进程调度方法的更多相关文章

  1. Linux内核的三种调度策略

    一 Linux内核的三种调度策略:   1,SCHED_OTHER 分时调度策略, 2,SCHED_FIFO实时调度策略,先到先服务.一旦占用cpu则一直运行.一直运行直到有更高优先级任务到达或自己放 ...

  2. linux内核的三种主要调度策略

    linux内核的三种主要调度策略: 1,SCHED_OTHER 分时调度策略, 2,SCHED_FIFO实时调度策略,先到先服务 3,SCHED_RR实时调度策略,时间片轮转 实时进程将得到优先调用, ...

  3. (笔记)Linux内核学习(三)之进程调度

    进程调度: 在可运行态进程之间分配有限处理器时间资源的内核子系统. 一 调度策略 1 进程类型 I/O消耗型进程:大部分时间用来提交I/O请求或是等待I/O请求,经常处于可运行状态,但运行时间短,等待 ...

  4. Liunx 环境下vsftpd的三种实现方法(超详细参数)

    以下文章介绍Liunx 环境下vsftpd的三种实现方法 ftp://vsftpd.beasts.org/users/cevans/vsftpd-2.0.3.tar.gz,目前已经到2.0.3版本.假 ...

  5. 成为Linux内核高手的四个方法

    首页 最新文章 资讯 程序员 设计 IT技术 创业 在国外 营销 趣文 特别分享 更多 > - Navigation -首页最新文章资讯程序员设计IT技术- Java & Android ...

  6. VMware虚拟机的三种联网方法及原理

    VMware虚拟机的三种联网方法及原理 博客分类: 操作系统 虚拟机Vmware互联网网络应用网络协议 一.Brigde——桥接  :默认使用VMnet0 1.原理: Bridge  桥"就 ...

  7. VMware虚拟机三种联网方法及原理

    VMware虚拟机三种联网方法及原理   一.Brigde——桥接:默认使用VMnet0   1.原理:   Bridge 桥"就是一个主机,这个机器拥有两块网卡,分别处于两个局域网中,同时 ...

  8. javase-常用三种遍历方法

    javase-常用三种遍历方法 import java.util.ArrayList; import java.util.Iterator; import java.util.List; public ...

  9. JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

随机推荐

  1. EL表达式获取参数值${param.name}等

    转自:http://www.html580.com/study/83.html EL表达式获取参数值${param.name}等 (1).${pageContext} 获取到 pageContext ...

  2. django 笔记8 url模板 自定义函数 simple_tag

    感谢alex老师~ 知识点: URL - 两个没见 url>路由系统> 函数或类 > 返回字符串 Form表单提交: 提交 >url>函数或类中的方法 -.. HttpR ...

  3. POJ 3668 枚举?

    枚举两点,算一下斜率 sort一遍 判个重 输出解 25行 搞定- //By SiriusRen #include <cmath> #include <cstdio> #inc ...

  4. IT男送什么礼物给女朋友呢?

    每到各种节日,加班到吐血的IT男们,总是没什么时间准备礼物给女朋友,偶尔想起又不知道送什么的好,女朋友虽然心里不说,多少有些难过.现在推荐朋友的羊毛毡手工店,每一件都是亲手制作,特别是可以个性定制,女 ...

  5. js之insertBefore(newElement,oldElement)

    insertBefore的用法,以及注意事项,并且模仿编写insertAfter()方法 DOM提供的一个名为insertBefore()的方法,用来将一个新元素插入到现有的元素的前面. 使用这个方法 ...

  6. PostgreSQL数据库常用脚本-初始化、备份、恢复推荐脚本

    公司最近开始逐步推广使用PostgreSQL,为方便开发人员和实施人员操作,特整理数据库初始化.备份.恢复的推荐脚本如下: 1. 连接数据库 psql -h 127.0.0.1 -p 1921 -U ...

  7. Xshell查看日志的基础使用

    2018\11\26 下载安装不多说,官网免费版即可,附上链接:https://www.netsarang.com/products/xsh_overview.html 打开后新建连接,输入主机ip即 ...

  8. echarts 绑定事件重复执行问题。

    网上所有,先调用.off 方法后再调用.on 绑定事件. 无效果,查看api未发现off方法,于是采用,先删除原先元素,后重新生成的方式. 场景描述. 用户查询时,每次结果都对应一张饼图.该张饼图绑定 ...

  9. linux 下查看二进制文件

    查看二进制有以下几种方法: 方法一:hexdump apt-get install libdata-hexdumper-perl 安装好之后就可以直接hexdump your_binary_file ...

  10. linux系统 硬链接和软链接

    背景: 当几个用户同在一个项目里工作时.经常须要共享文件. 假设一个共享文件同一时候出如今属于不同用户的不同文件夹下.工作起来就非常方便. 比如B和C文件夹下有一文件D是两者都能够訪问和改动的共享文件 ...