Algoritme Penjadwalan Sistem Operasi
Penjadwal Proses menjadwalkan proses yang berbeda untuk ditugaskan ke CPU berdasarkan algoritma penjadwalan tertentu. Ada enam algoritma penjadwalan proses populer yang akan kita bahas dalam bab ini -
- Penjadwalan First-Come, First-Served (FCFS)
- Penjadwalan Shortest-Job-Next (SJN)
- Penjadwalan Prioritas
- Sisa Waktu Tersingkat
- Penjadwalan Round Robin (RR)
- Penjadwalan Antrian Beberapa Tingkat
Algoritme ini juga non-preemptive or preemptive. Algoritme non-preemptive dirancang sedemikian rupa sehingga setelah proses memasuki status berjalan, proses tidak dapat dilakukan sebelum menyelesaikan waktu yang dialokasikan, sedangkan penjadwalan preemptive didasarkan pada prioritas di mana penjadwal dapat mendahului proses yang berjalan dengan prioritas rendah kapan saja ketika prioritas tinggi proses memasuki keadaan siap.
First Come First Serve (FCFS)
- Pekerjaan dijalankan berdasarkan siapa cepat dia dapat.
- Ini adalah algoritma penjadwalan preemptive dan pre-emptive.
- Mudah dipahami dan diterapkan.
- Implementasinya berdasarkan antrian FIFO.
- Performa buruk karena waktu tunggu rata-rata tinggi.
Wait time dari setiap proses adalah sebagai berikut -
Proses | Waktu Tunggu: Waktu Layanan - Waktu Kedatangan |
---|---|
P0 | 0 - 0 = 0 |
P1 | 5 - 1 = 4 |
P2 | 8 - 2 = 6 |
P3 | 16 - 3 = 13 |
Waktu Tunggu Rata-rata: (0 + 4 + 6 + 13) / 4 = 5.75
Pekerjaan Tersingkat Berikutnya (SJN)
Ini juga dikenal sebagai shortest job first, atau SJF
Ini adalah algoritma penjadwalan preemptive dan preemptive.
Pendekatan terbaik untuk meminimalkan waktu tunggu.
Mudah diimplementasikan dalam sistem Batch di mana waktu CPU yang diperlukan telah diketahui sebelumnya.
Tidak mungkin diterapkan dalam sistem interaktif di mana waktu CPU yang diperlukan tidak diketahui.
Pengolah harus mengetahui sebelumnya berapa lama waktu yang dibutuhkan untuk proses tersebut.
Diberikan: Tabel proses, dan waktu Kedatangan mereka, Waktu eksekusi
Proses | Jam kedatangan | Waktu eksekusi | Waktu Layanan |
---|---|---|---|
P0 | 0 | 5 | 0 |
P1 | 1 | 3 | 5 |
P2 | 2 | 8 | 14 |
P3 | 3 | 6 | 8 |
Waiting time dari setiap proses adalah sebagai berikut -
Proses | Waktu menunggu |
---|---|
P0 | 0 - 0 = 0 |
P1 | 5 - 1 = 4 |
P2 | 14 - 2 = 12 |
P3 | 8 - 3 = 5 |
Average Wait Time: (0 + 4 + 12 + 5)/4 = 21 / 4 = 5.25
Priority Based Scheduling
Priority scheduling is a non-preemptive algorithm and one of the most common scheduling algorithms in batch systems.
Each process is assigned a priority. Process with highest priority is to be executed first and so on.
Processes with same priority are executed on first come first served basis.
Priority can be decided based on memory requirements, time requirements or any other resource requirement.
Given: Table of processes, and their Arrival time, Execution time, and priority. Here we are considering 1 is the lowest priority.
Process | Arrival Time | Execution Time | Priority | Service Time |
---|---|---|---|---|
P0 | 0 | 5 | 1 | 0 |
P1 | 1 | 3 | 2 | 11 |
P2 | 2 | 8 | 1 | 14 |
P3 | 3 | 6 | 3 | 5 |
Waiting time of each process is as follows −
Process | Waiting Time |
---|---|
P0 | 0 - 0 = 0 |
P1 | 11 - 1 = 10 |
P2 | 14 - 2 = 12 |
P3 | 5 - 3 = 2 |
Average Wait Time: (0 + 10 + 12 + 2)/4 = 24 / 4 = 6
Shortest Remaining Time
Shortest remaining time (SRT) is the preemptive version of the SJN algorithm.
The processor is allocated to the job closest to completion but it can be preempted by a newer ready job with shorter time to completion.
Impossible to implement in interactive systems where required CPU time is not known.
It is often used in batch environments where short jobs need to give preference.
Round Robin Scheduling
Round Robin is the preemptive process scheduling algorithm.
Each process is provided a fix time to execute, it is called a quantum.
Once a process is executed for a given time period, it is preempted and other process executes for a given time period.
Context switching is used to save states of preempted processes.
Wait time of each process is as follows −
Process | Wait Time : Service Time - Arrival Time |
---|---|
P0 | (0 - 0) + (12 - 3) = 9 |
P1 | (3 - 1) = 2 |
P2 | (6 - 2) + (14 - 9) + (20 - 17) = 12 |
P3 | (9 - 3) + (17 - 12) = 11 |
Average Wait Time: (9+2+12+11) / 4 = 8.5
Multiple-Level Queues Scheduling
Multiple-level queues are not an independent scheduling algorithm. They make use of other existing algorithms to group and schedule jobs with common characteristics.
- Multiple queues are maintained for processes with common characteristics.
- Each queue can have its own scheduling algorithms.
- Priorities are assigned to each queue.
For example, CPU-bound jobs can be scheduled in one queue and all I/O-bound jobs in another queue. The Process Scheduler then alternately selects jobs from each queue and assigns them to the CPU based on the algorithm assigned to the queue.