Beruflich Dokumente
Kultur Dokumente
A priority number (integer) is associated with each process The CPU is allocated to the process with the highest priority (smallest integer highest priority) A priority scheduling algorithm can be preemptive or non preemptive.
A Preemptive priority scheduling algorithm will preempt the CPU if the priority of the newly arrived process is higher than the priority of the currently running process..
SPRING 2011 - 102
A Non preemptive priority scheduling algorithm will simply put the new process at the tail of the Ready Queue.
Non Preemptive
Preemptive
SJF is a priority scheduling where priority is the predicted next CPU burst time.
Problem Starvation
low priority processes may never execute
Solution Aging
as time progresses increase the priority of the process
Round-robin scheduling
Pre emptive
Processes run only for a limited amount of time . After this time has elapsed, the process is preempted and added to the end of the ready queue
If there are n processes in the ready queue and the time quantum is q, then each process gets 1/n of the CPU time in chunks of at most q time units at once. No process waits more than (n-1)q time units.
SPRING 2011 - 102
10
Process
P1 P2 P3 P4
Burst Time
53 17 68 24
Time Quantum = 20
Process P1 P2 P3 P4
Burst Time 53 33 13 17 68 48 28 8 24 4
19 APRIL 2011
Process
P1 P2 P3 P4
Turnaround Time
134 37 162 121
Waiting Time
134 53 = 81 37 17 = 20 162 68 = 94 121 24 = 97
19 APRIL 2011
13
14
15
Quantum size
Very large quantum size
Processes run for long periods Degenerates to FIFO
16
Quantum size
Depends on system
Interactive: response time key factor Batch: turnaround time key factor
17
Fixed priority scheduling; (i.e., serve all from foreground then from background). Possibility of starvation. Time slice each queue gets a certain amount of CPU time which it can schedule amongst its processes; i.e., 80% to foreground in RR 20% to background in FCFS
20
Short I/O-bound interactive processes should generally run before processor-bound batch processes
Arriving processes enter the highest-level queue and execute with higher priority than processes in lower queues
Gives short processes and I/O-bound processes higher priority Long processes will run when short and I/O-bound processes terminate
Similarly Aging can be done to prevent starvation i.e. the processes that waits too long in the lower priority queue are moved to a higher priority queue Multilevel-feedback-queue scheduler defined by the following parameters:
number of queues
scheduling algorithms for each queue method used to determine when to upgrade a process method used to determine when to demote a process method used to determine which queue a process will enter when that process needs service
Three queues:
Scheduling
A new job enters queue Q0 which is served FCFS. When it gains CPU, job receives 8 milliseconds. If it does not finish in 8 milliseconds, job is moved to queue Q1.
At Q1 job is again served FCFS and receives 16 additional milliseconds. If it still does not complete, it is preempted and moved to queue Q2.
24
25