Kongkurensi Dalam Sistem Operasi
Kongkurensi
Kongkurensi Dalam Sistem Operasi |
Hello good millennial, jumpa lagi di blogger joeshapictures tema hari ini ialah perihal "Kongkurensi Dalam Sistem Operasi" penasaran, yuk kita baca !
Proses-proses disebut kongkuren kalau proses-proses (lebih dari 1 proses) berada pada ketika yang sama. Proses-proses kongkuren sanggup sepenuhnya tak bergantung dengan lainnya tapi sanggup juga saling berinteraksi/kerjasama. Proses-proses yang berinteraksi memerlukan sinkronisasi/koordinasi semoga terkendali dengan baik.
Proses-proses disebut kongkuren kalau proses-proses (lebih dari 1 proses) berada pada ketika yang sama. Proses-proses kongkuren sanggup sepenuhnya tak bergantung dengan lainnya tapi sanggup juga saling berinteraksi/kerjasama. Proses-proses yang berinteraksi memerlukan sinkronisasi/koordinasi semoga terkendali dengan baik.
Contoh Kasus :
- Sambil menunggu selesainya layanan (misalnya transfer data oleh modem) pemakai sanggup berinteraksi dengan aplikasi lain menyerupai aplikasi permainan game atau mengetikkan perintah pada text editor.
- Proses tersebut harus berjalan konkuren dan tidak terjadi deadlock (hang).
Kegiatan yang berafiliasi dengan kongkurensi :
-Alokasi waktu pemroses untuk proses-proses yang aktif.
-Pemakaian bersama & persaingan mendapat sumber daya.
-Komunikasi antar proses.
-Sinkronisasi acara banyak proses.
Kesulitan dalam Kongkurensi
-Pemakaian bersama sumber daya global
-Pengelolaan sumber daya semoga optimal
-Pencarian kesalahan pemrograman
Penanganan Kongkurensi
-Mengetahui proses-proses yang aktif
-Mengatur alokasi dan dealokasi bermacam-macam sumber daya untuk tiap proses yang aktif
-Proteksi data dan sumber daya fisik proses
-Hasil-hasil proses harus independen
Persaingan dan Kerjasama Antar Proses
- Persaingan antar proses terjadi ketika beberapa proses akan memakai sumber daya yang sama.
- Jika ada 2 proses yang akan mengakses ke suatu sumber daya tunggal, kemudian satu proses dialokasikan ke sumber daya tersebut oleh SO ? proses yang lainnya akan menunggu.
- Pada kasus yang ekstrim, proses yang menunggu tersebut ada kemungkinan tidak akan pernah mendapat saluran ke sumber daya sehingga tidak akan pernah tamat dengan sempurna.
- Hal ini juga terjadi akhir antar proses yang saling tidak peduli. Proses-proses yang mengalami kongkuren sanggup bangkit sendiri (independen) atau sanggup saling berinteraksi, sehingga membutuhkan sinkronisasi atau koordinasi proses yang baik.
- Meskipun proses-proses tidak bekerja bersama, SO perlu mengatur persaingan diantara proses-proses itu dalam memperoleh sumber daya yang terbatas
Contoh :
1. Dua buah aplikasi (word & corel) berusaha mengakses printer yang sama.
2. Bila kedua aplikasi mengakses printer yang sama benar-benar secara bersamaan maka kedua proses akan memperoleh hasil yang tidak di kehendaki.
Kondisi dan Masalah
Beberapa kondisi dan problem yang sanggup muncul pada kongkurensi antara lain :
a. Mutual exclusion
b. Deadlock
c. Starvation
a. Mutual Exclusion
Mutual exclusion ialah jaminan hanya satu proses yang mengakses sumber daya pada suatu interval waktu tertentu, sedangkan proses lain dihentikan mengerjakan hal yang sama.
pola : sumberdaya printer hanya sanggup diakses 1 proses, tidak sanggup bersamaan ? sumber daya ini disebut sumber daya kritis
b. Deadlock
Adalah banyak proses yang saling menunggu hasil dari proses yang lain untuk sanggup melanjutkan atau menuntaskan tugasnya.
Misal : 2 proses P0 dan P1. 2 sumber daya R0 dan R1. P0 meminta sumberdaya R0.
Sumber daya R1 dialokasikan ke P1.
Skenario yang menjadikan deadlock :
-P0 dialokasikan R0
-P1 dialokasikan R1
-P0 sambil masih menggenggam R0, meminta R1
-P1 sambil masih menggenggam R1, meminta R0
-Terjadi deadlock alasannya ialah sama-sama akan saling menunggu
c. Starvation
Adalah suatu proses akan menunggu suatu insiden atau hasil suatu proses lain, supaya sanggup menuntaskan tugasnya, tetapi insiden yang dinantikan tidak pernah terjadi alasannya ialah selalu diambil lebih dulu oleh proses yang lain.
Contoh :
Terdapat tiga proses, yaitu P1, P2 dan P3. P1, P2 dan P3 memerlukan pengaksesan sumber daya R secara periodik
Skenario berikut terjadi :
P1 sedang diberi sumber daya R sedangkan P2 dan P3 diblocked menunggu sumber daya R.
Ketika P1 keluar dari critical section, maka P2 dan P3 diijinkan mengakses R. Asumsi P3 diberi hak akses, kemudian sehabis selesai, hak saluran kembali diberikan ke P1 yang ketika itu kembali membutuhkan sumber daya R.
Jika tunjangan hak saluran bergantian terus-menerus antara P1 dan P3, maka P2 tidak pernah memperoleh pengaksesan sumber daya R.
Dalam kondisi ini memang tidak terjadi deadlock, hanya saja P2 mengalami starvation (tidak ada kesempatan untuk dilayani).
Terima kasih sudah membaca semoga apa yang kita baca hari ini sanggup bermanfaat bagi kita semua, sebelum meninggalkan blogger joeshapictures sebaiknya di share dulu, apa yang kita sanggup hari ini ada baiknya kalau kita membagikan pengetahuan kepada orang lain. Sampai jumpa di artikel selanjutnya . . .
Belum ada Komentar untuk "Kongkurensi Dalam Sistem Operasi"
Posting Komentar