Sistem Operasi - Penjadwalan Proses

Definisi

Penjadwalan proses adalah aktivitas manajer proses yang menangani penghapusan proses yang sedang berjalan dari CPU dan pemilihan proses lain berdasarkan strategi tertentu.

Penjadwalan proses adalah bagian penting dari sistem operasi Multiprogramming. Sistem operasi semacam itu memungkinkan lebih dari satu proses untuk dimuat ke dalam memori yang dapat dieksekusi pada satu waktu dan proses yang dimuat berbagi CPU menggunakan multiplexing waktu.

Proses Penjadwalan Antrian

OS memelihara semua PCB dalam Antrian Penjadwalan Proses. OS memelihara antrian terpisah untuk setiap status proses dan PCB dari semua proses dalam status eksekusi yang sama ditempatkan dalam antrian yang sama. Ketika status proses diubah, PCB-nya dibatalkan tautannya dari antrean saat ini dan dipindahkan ke antrean status baru.

Sistem Operasi mempertahankan antrian penjadwalan proses penting berikut -

  • Job queue - Antrian ini menyimpan semua proses dalam sistem.

  • Ready queue- Antrian ini menyimpan satu set semua proses yang berada di memori utama, siap dan menunggu untuk dieksekusi. Proses baru selalu dimasukkan ke dalam antrian ini.

  • Device queues - Proses yang diblokir karena tidak tersedianya perangkat I / O merupakan antrian ini.

OS dapat menggunakan kebijakan yang berbeda untuk mengelola setiap antrian (FIFO, Round Robin, Priority, dll.). Penjadwal OS menentukan cara memindahkan proses antara antrian siap dan menjalankan yang hanya dapat memiliki satu entri per inti prosesor pada sistem; pada diagram di atas, telah digabungkan dengan CPU.

Model Proses Dua-Negara

Model proses dua status mengacu pada status berjalan dan tidak berjalan yang dijelaskan di bawah ini -

SN Status & Deskripsi
1

Running

Saat proses baru dibuat, proses tersebut masuk ke dalam sistem seperti dalam status berjalan.

2

Not Running

Proses yang tidak berjalan disimpan dalam antrian, menunggu giliran untuk dieksekusi. Setiap entri dalam antrian adalah penunjuk ke proses tertentu. Antrian diimplementasikan dengan menggunakan linked list. Penggunaan dispatcher adalah sebagai berikut. Ketika suatu proses terputus, proses itu ditransfer dalam antrian tunggu. Jika proses telah selesai atau dibatalkan, proses tersebut akan dibuang. Dalam kedua kasus tersebut, petugas operator kemudian memilih proses dari antrian untuk dieksekusi.

Penjadwal

Penjadwal adalah perangkat lunak sistem khusus yang menangani penjadwalan proses dengan berbagai cara. Tugas utama mereka adalah memilih pekerjaan yang akan dikirim ke sistem dan memutuskan proses mana yang akan dijalankan. Penjadwal terdiri dari tiga jenis -

  • Penjadwal Jangka Panjang
  • Penjadwal Jangka Pendek
  • Penjadwal Jangka Menengah

Penjadwal Jangka Panjang

Ini juga disebut a job scheduler. Penjadwal jangka panjang menentukan program mana yang dimasukkan ke sistem untuk diproses. Ini memilih proses dari antrian dan memuatnya ke dalam memori untuk dieksekusi. Proses dimuat ke dalam memori untuk penjadwalan CPU.

Tujuan utama dari penjadwal pekerjaan adalah untuk menyediakan campuran pekerjaan yang seimbang, seperti terikat I / O dan terikat prosesor. Ini juga mengontrol tingkat multiprogramming. Jika derajat multiprogramming stabil, maka laju rata-rata pembuatan proses harus sama dengan laju keberangkatan rata-rata proses yang meninggalkan sistem.

Pada beberapa sistem, penjadwal jangka panjang mungkin tidak tersedia atau minimal. Sistem operasi berbagi waktu tidak memiliki penjadwal jangka panjang. Ketika suatu proses mengubah status dari baru menjadi siap, maka ada penggunaan penjadwal jangka panjang.

Penjadwal Jangka Pendek

Itu juga disebut sebagai CPU scheduler. Tujuan utamanya adalah untuk meningkatkan kinerja sistem sesuai dengan kriteria yang dipilih. Ini adalah perubahan dari status siap ke status berjalan dari proses. Penjadwal CPU memilih proses di antara proses yang siap untuk dijalankan dan mengalokasikan CPU ke salah satunya.

Penjadwal jangka pendek, juga dikenal sebagai dispatcher, membuat keputusan tentang proses mana yang akan dijalankan selanjutnya. Penjadwal jangka pendek lebih cepat daripada penjadwal jangka panjang.

Penjadwal Jangka Menengah

Penjadwalan jangka menengah adalah bagian dari swapping. Ini menghapus proses dari memori. Ini mengurangi tingkat multiprogramming. Penjadwal jangka menengah bertugas menangani proses keluar yang ditukar.

Proses yang sedang berjalan dapat ditangguhkan jika membuat permintaan I / O. Proses yang ditangguhkan tidak dapat membuat kemajuan apa pun menuju penyelesaian. Dalam kondisi ini, untuk menghapus proses dari memori dan memberi ruang untuk proses lainnya, proses yang ditangguhkan dipindahkan ke penyimpanan sekunder. Proses ini disebutswapping, dan proses tersebut dikatakan akan ditukar atau diluncurkan. Pertukaran mungkin diperlukan untuk meningkatkan campuran proses.

Perbandingan antar Scheduler

SN Penjadwal Jangka Panjang Penjadwal Jangka Pendek Penjadwal Jangka Menengah
1 Ini adalah penjadwal pekerjaan Ini adalah penjadwal CPU Ini adalah penjadwal pertukaran proses.
2 Kecepatan lebih rendah dari penjadwal jangka pendek Kecepatan tercepat di antara dua lainnya Kecepatan ada di antara penjadwal jangka pendek dan panjang.
3 Ini mengontrol tingkat multiprogramming Ini memberikan kontrol yang lebih rendah atas tingkat multiprogramming Ini mengurangi tingkat multiprogramming.
4 Ini hampir tidak ada atau minimal dalam sistem pembagian waktu Ini juga minimal dalam sistem pembagian waktu Ini adalah bagian dari sistem berbagi waktu.
5 Ini memilih proses dari pool dan memuatnya ke dalam memori untuk dieksekusi Ini memilih proses yang siap untuk dieksekusi Itu dapat memperkenalkan kembali proses ke dalam memori dan eksekusi dapat dilanjutkan.

Pengalih Konteks

Sakelar konteks adalah mekanisme untuk menyimpan dan memulihkan status atau konteks CPU di blok Kontrol Proses sehingga eksekusi proses dapat dilanjutkan dari titik yang sama di lain waktu. Dengan menggunakan teknik ini, pengalih konteks memungkinkan banyak proses untuk berbagi satu CPU. Peralihan konteks adalah bagian penting dari fitur sistem operasi multitasking.

Ketika penjadwal mengalihkan CPU dari menjalankan satu proses ke menjalankan proses lainnya, status dari proses yang sedang berjalan disimpan ke dalam blok kontrol proses. Setelah ini, status untuk menjalankan proses berikutnya dimuat dari PCBnya sendiri dan digunakan untuk mengatur PC, register, dll. Pada titik itu, proses kedua dapat mulai dijalankan.

Sakelar konteks intensif secara komputasi karena register dan status memori harus disimpan dan dipulihkan. Untuk menghindari jumlah waktu pengalihan konteks, beberapa sistem perangkat keras menggunakan dua atau lebih set register prosesor. Saat proses dialihkan, informasi berikut disimpan untuk digunakan nanti.

  • Penghitung Program
  • Informasi penjadwalan
  • Nilai register dasar dan batas
  • Register saat ini digunakan
  • Status Berubah
  • Informasi I / O State
  • Informasi akuntan