Proses dalam sistem terdistribusi dijelaskan dalam tiga kalimat. Proses merupakan kode program dan informasi lain yang sedang dieksekusi. Status proses meliputi running, ready, blocked, terminated. Kontrol blok proses berisi informasi tentang status, alamat instruksi, dan sumber daya proses.
1. Tinjauan sistem keseluruhan (hardware, metode kriptografi, matematika, pemrograman berorientasi mesin, aplikasi dll)
2. Dasar Arsitektur Sistem, Sistem Operasi
3. Pembahasan Paralelisme
4. Pembahasan SUmber daya komputer
5. Trade Off sesuai kebutuhan
1. Tinjauan sistem keseluruhan (hardware, metode kriptografi, matematika, pemrograman berorientasi mesin, aplikasi dll)
2. Dasar Arsitektur Sistem, Sistem Operasi
3. Pembahasan Paralelisme
4. Pembahasan SUmber daya komputer
5. Trade Off sesuai kebutuhan
This presentation tell you about the task scheduling in a multiprocessor system. Kind of scheduling algorithm (utilization balancing, next-fit, bin-packing, etc) are discussed here. (Most of this slide using Indonesian Language).
Aufar Fajar - Computer Engineering, MCU
This presentation tell you about the task scheduling in a multiprocessor system. Kind of scheduling algorithm (utilization balancing, next-fit, bin-packing, etc) are discussed here. (Most of this slide using Indonesian Language).
Aufar Fajar - Computer Engineering, MCU
2. Definisi proses
Menurut Silberschatz, suatu proses adalah lebih dari sebuah kode
program, yang kadang disebut text section. Proses juga mencakup
program counter, yaitu sebuah stack untuk menyimpan alamat dari
instruksi yang akan dieksekusi selanjutnya dan register. Sebuah
proses pada umumnya juga memiliki sebuah stack yang berisikan
data-data yang dibutuhkan selama proses dieksekusi seperti
parameter metoda, alamat return dan variabel lokal, dan sebuah
data section yang menyimpan variabel global.
3. Status Proses
Bila sebuah proses dieksekusi, maka statusnya akan berubah-ubah.
Status dari sebuah proses mencerminkan aktivitas atau keadaan dari
proses itu sendiri. Berikut ini adalah status-status yangmungkin
dimiliki sebuah proses menurut Tanenbaum:
– Running: pada saat menggunakan CPU pada suatu waktu.
– Ready: proses diberhentikan sementara karena menunggu
proses lain untuk dieksekusi.
– Blocked: tidak dijalankan sampai event dari luar, yang
berhubungan dengan proses tersebut terjadi.
4. Status Proses
Ada tiga kemungkinan bila sebuah proses memiliki status running:
– Jika program telah selesai dieksekusi maka status dari proses
tersebut akan berubah menjadi Terminated.
– Jika waktu yang disediakan oleh OS untuk proses tersebut sudah
habis maka akan terjadi interrupt dan proses tersebut kini
berstatus Ready.
– Jika suatu event terjadi pada saat proses dieksekusi (seperti ada
request I/O) maka proses tersebut akan menunggu event
tersebut selesai dan proses berstatusWaiting.
6. Proses Control Block
Tiap proses digambarkan dalam sistem operasi oleh sebuah process
control block (PCB) - juga disebut sebuah control block.
PCB berisikan banyak bagian dari informasi yang berhubungan
dengan sebuah proses yang spesi…k, termasuk hal-hal di bawah ini:
– Status proses: status mungkin, new, ready, running, waiting,
halted, dan juga banyak lagi.
– Program counter: suatu stack yang berisi alamat dari instruksi
selanjutnya untuk dieksekusi untuk proses ini.
8. Thread
Thread merupakan unit dasar dari penggunaan CPU, yang terdiri dari
Thread_ID, program counter, register set, dan stack.
Sebuah thread berbagi code section, data section, dan sumber daya
sistem operasi dengan Thread lain yang dimiliki oleh proses yang
sama.
Thread juga sering disebut dengan lightweight process.
Sebuah proses tradisional atau heavyweight process mempunyai
thread tunggal yang berfungsi sebagai pengendali.
Perbedaan antara proses dengan thread tunggal dengan proses
dengan thread yang banyak adalah proses dengan thread yang
banyak dapat mengerjakan lebih dari satu tugas pada satu satuan
waktu.
9. Contoh Thread yang memiliki lightweight
process
Kalau web server berjalan sebagai proses yang hanya mempunyai
thread tunggal maka ia hanya dapat melayani satu klien pada
satu satuan waktu saja.
Bila ada klien lain yang ingin mengajukan permintaan maka ia harus
menunggu sampai klien sebelumnya selesai dilayani.
Solusinya
adalah dengan membuat web server menjadi multi-threading.
Dengan ini maka sebuah web server akan membuat thread yang
akan mendengar permintaan klien, ketika permintaan lain diajukan
maka web server akan menciptakan thread lain yangakan melayani
permintaan tersebut.ma data dari network.
10. Keuntungan Thread
Keuntungan dari program yang multithreading dapat dipisah
menjadi empat kategori :
- Responsi
- Berbagi sumber daya
- Ekonomi
- Utilisasi arsitektur multiprocessor
11. Multithreading Model
Many to one Model
Many-to-One model memetakan banyak user-level thread ke satu
kernel thread. Pengaturan thread dilakukan di user space, oleh
karena itu ia efisien tetapi ia mempunyai kelemahan yang sama
dengan user thread.
12. Multithreading Model
One to one Model
One-to-Onemodelmemetakan setiap user thread ke kernel thread.
Ia menyediakan lebih banyak concurrency dibandingkanMany-to-
One model. Keuntungannya sama dengan keuntungan kernel thread.
Kelemahannyamodel ini adalah setiap pembuatan user thread
membutuhkan pembuatan kernel thread.
13. Multithreading Model
Many to many Model
Many-to-many model multiplexes banyak user-level thread ke
kernel thread yang jumlahnya lebih kecil atau sama banyaknya
dengan user-level thread. Jumlah kernel thread dapat spesi…k untuk
sebagian aplikasi atau sebagian mesin