一个计算机系统为了实现实时性,必须对cpu及其他资源进行管理。在linux操作系统中,实时系统可以分为软实时和硬实时两种。
实时操作系统的调度算法主要分为以下三种:
基于优先级的调度算法:
静态优先级(RM):给得到运行的所有进程静态地分配一个优先级,RM算法根据任务的执行周期 的长短来分配优先级
动态优先级(EDF):根据deadline分配优先级
基于cpu的使用比例
基本思想主要有两种:
1、调节各个进程出现在就绪队列队首的频率,并调度队首的进程执行
2、逐次调度就绪队列的各个进程,但根据权重分配时间片
基于时间
适用于稳定的,对各个任务的开始,切换以及结束时间等事件做出明确的说明和设计的系统。
linux中的调度算法有如下三种:
RR:
FIFO:
这两种都是针对实时进程的调度算法,两者的区别在于:对于优先级相同的进程,RR是采用轮转的方式,而FIFO是采用先来先服务的方式,一个执行完了再执行另外一个。
进程 | 优先级 |
---|---|
A | 1 |
B | 2 |
C | 2 |
D | 3 |
E | 3 |
假设B进程比C进程早到,而E进程比D进程早到,则采用FIFO的调度顺序为:
A-B-C-E-D
采用RR的调度顺序为:
A-B-C-B-C......-E-D-E-D......
NORMAL:
普通进程所采用的调度策略
转载于:https://blog.51cto.com/4989715/1416852