linux进程调度(修改中)

Linux抢占式调度与进程优先级解析
本文探讨了Linux操作系统中的抢占式多任务调度,其中调度程序根据进程的I/O消耗型和处理器消耗型特性决定执行优先级。nice值和实时优先级是决定进程执行顺序的关键因素,时间片用于控制进程运行时间。O(1)调度和CFS调度策略通过不同的方式优化了进程的调度效率。

调度程序负责决定将哪个进程投入运行,何时运行以及运行多长时间。

多任务系统可划分为两类:非抢占式多任务和抢占式多任务。

Linux提供了抢占式的多任务模式,由调度程序来决定什么时候停止一个进程的运行,以便其他程序执行。这个强制的挂起动作就叫抢占,进程在被抢占之前运行的时间就是时间片。

策略决定调度程序什么时候让进程运行,进程可以被划分为I/O消耗型和处理器消耗型。前者指进程大部分时间用来提交I/O请求或是等待I/O请求。处理器消耗型的则把时间大多用在执行代码上。当然进程也可以同时展示这两种特性。

进程优先级:

nice值-20到+19默认为0,越大越低。

实时优先级,0到99,越高优先级越高。

时间片是进程被抢占前能持续运行的时间。太短太长都不合适。进程是资源管理的单位,线程才是调度的单位。调度就是把系统中的task调度到cpu上去执行。

O(1)调度:由共用的链表变成了per-cpu链表,不同的优先级放在不同的队列中,(140个?)所有的这些串成链表,有两个队列,分别是时间片有剩余的(active)和时间片无剩余的队列,执行时先在active中按照优先级来寻找进程链表。

CFS调度:

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值