调度策略 http://book.2cto.com/201302/16285.html

转载 2015年11月18日 21:43:55

RHEL6(Linux 2.6.32)中定义了下列调度策略。

SCHED_OTHER

SCHED_FIFO

SCHED_RR

SCHED_BATCH

SCHED_IDLE

下面将分别对各调度策略进行介绍。

SCHED_OTHER

这是Linux的标准调度策略,也是所谓TSS调度策略。

在RHEL5等Linux 2.6.23之前的内核所使用的以优先级为基础的O(1)调度程序中,还加入了经验性的判断,优先为会话进程赋予执行权。TSS的时间片由优先级决定。

在RHEL6等Linux 2.6.23之后的CFS中,会公平地为所有TSS策略的进程分配CPU时间。其时间片是动态决定的。

SCHED_FIFO

这是实时调度策略,即具有静态优先级的调度策略。Linux内核中能够为实时调度策略的进程指定的优先级为1~99。使用了SCHED_FIFO调度策略的进程,除了等待I/O完成时休眠、自发休眠或优先级更高的实时进程获得优先权以外,不会释放执行权。

使用SCHED_FIFO的实时调度策略时,需要注意的是,它的进程不会自动释放CPU,也就是说执行权不会转移到其他进程。例如,实时调度策略的进程陷入无限循环时,其他所有优先级较低的进程永远不会被赋予执行权,此时系统就会死机。

小贴士:另外,要对进程使用实时调度策略,必须有root权限。

SCHED_RR

这也是实时调度策略。RR是round robin(轮询)的缩写,与SCHED_FIFO不同的是,它具有时间片。时间片使用完时,执行权将转移到其他进程。

在2.6.23以前导入的O(1)调度程序中,时间片是由优先级决定的。

引入CFS时SCHED_RR的调度策略也进行了修改,时间片变为固定值(100毫秒)。

SCHED_BATCH

指定这个调度策略的进程不是会话型,不会根据休眠时间更改优先级。

例如,备份处理等需要进行较大文件或大量文件存取的进程,是通过磁盘I/O来中止的。在TSS调度策略中,因为这个休眠,正在进行备份处理的进程优先级提高,需要应答性的shell等的优先级相对降低。这就会导致系统的应答性降低。

在RHEL5的O(1)调度程序中,使用了这个调度策略的进程被识别为休眠时间为0的CPU bound进程。因此,优先级必然会变成比会话型shell进程低。

对非会话型的进程(即所谓的补丁处理)使用这个调度策略,就可以使会话型进程的优先级保持相对较高,并确保应答性。

在Linux 2.6.23导入的CFS中,对进行补丁处理的进程改变了处理的方法,优先级不会因休眠时间而发生变化。在导入CFS的RHEL6中,SCHED_BATCH和SCHED_OTHER几乎没有区别,因此可以不使用。

SCHED_IDLE

这是由CFS导入的新等级。CPU空闲时,即SCHED_IDLE等级以外处于可执行状态的进程消失时,将被赋予执行权。也就是它将成为优先级最低的进程。

特殊标志:SCHED_RESET_ON_FORK

为了限制实时调度策略的进程运行,而为调度策略添加了标志flag。设置了标志flag的实时调度策略进程,在执行fork()时,新生成的子进程就成为SCHED_OTHER策略的进程。

如下例所示,通过向实时调度策略添加标志flag来设置。

sched_setscheduler(pid, SCHED_FIFO|SCHED_RESET_ON_FORK, &param);

http://www.2cto.com/kf/201410/344061.html

方法1:利用windows文本文件编码特点。 windows下,Unicode、Unicode big endian和UTF-8编码的txt文件的开头会多出几个字节,分别是FF、FE(Unicode)...

Android开发之MdiaPlayer详解 http://www.2cto.com/kf/201408/325309.html

MediaPlayer类可用于控制音频/视频文件或流的播放,我曾在《Android开发之基于Service的音乐播放器》一文中介绍过它的使用。下面让我们看一下MediaPlayer类的详细介绍。 ...
  • HonNING
  • HonNING
  • 2015年03月05日 11:50
  • 1154

http://www.2cto.com/kf/201402/280576.html

Cocos2dx 3.0 提高篇(十一) xml文档的读取与调用 假设有一个名为 label.xml 的文档,内容如下: ? 1 ...

inux的安装和启动流程(http://www.2cto.com/os/201208/145165.html)

inux的安装和启动流程   自己整理的linux的安装和启动   1. Linux安装流程 1.1 安装过程总览 1. BIOS加电自检   2. 运行isolinux目录下面的is...
  • VMA_LMA
  • VMA_LMA
  • 2014年02月25日 17:05
  • 1917

Java生成二维码,转载!感觉不错Mark下(出处:http://www.2cto.com/kf/201108/98471.html)

周末试用下Android手机的二维码扫描软件,扫描了下火车票、名片等等,觉得非常不错很有意思的。当然Java也可以实现这些,现在就分享下如何简单用Java实现二维码中QRCode的编码和解码(可以手机...

史上最强大ios app网络抓取 from http://www.2cto.com/net/201306/221430.html

iOS应用(包括移动应用)的网络分析,一般采用将移动设备上的流量导入到PC机上,利用PC上成熟的数据包分析工具例如wireshark等来进行分析的方法。   总的来说,有以下三种方法: ...

.net IOC模式(转自http://book.51cto.com/art/200803/67575.htm)

2011-09-02 15:17   控制反转IOC和依赖注入DI 控制反转(Inversion of Control,IOC)和依赖注入(Dependency Injec...

jQuery事件的旅程原文 http://book.51cto.com/art/200807/79150.htm

当页面上发生一个事件时,每个层次上的DOM元素都有机会处理这个事件。以下面的页面模型为例:    当在浏览器中形象化地呈现这些由嵌套的代码构成的元素...

转自: http://book.51cto.com/art/201004/193743.htm

6.2.3  Spring 2.5配置文件详解 Spring配置文件是用于指导Spring工厂进行Bean生产、依赖关系注入(装配)及Bean实例分发的"图纸"。Java EE程序员必须学会并灵活应...

linux系统下创建oracle表空间和用户权限查询。转自http://www.2cto.com/os/201212/173801.htmllinux系统下创建oracle表空间和用户权限查询 创

linux系统下创建oracle表空间和用户权限查询   创建用户和表空间:    www.2cto.com   1、登录linux,以oracle用户登录(如果是root用户...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:调度策略 http://book.2cto.com/201302/16285.html
举报原因:
原因补充:

(最多只允许输入30个字)