Sistem Operasi - Multi-Threading

Apa itu Thread?

Utas adalah aliran eksekusi melalui kode proses, dengan penghitung programnya sendiri yang melacak instruksi mana yang akan dieksekusi berikutnya, register sistem yang menyimpan variabel kerjanya saat ini, dan tumpukan yang berisi riwayat eksekusi.

Sebuah utas berbagi dengan utas rekannya beberapa informasi seperti segmen kode, segmen data, dan file terbuka. Ketika satu utas mengubah item memori segmen kode, semua utas lainnya melihatnya.

Utas juga disebut a lightweight process. Utas menyediakan cara untuk meningkatkan kinerja aplikasi melalui paralelisme. Threads merupakan pendekatan perangkat lunak untuk meningkatkan kinerja sistem operasi dengan mengurangi overhead thread yang setara dengan proses klasik.

Setiap utas memiliki tepat satu proses dan tidak ada utas yang dapat berada di luar proses. Setiap utas mewakili aliran kontrol yang terpisah. Thread telah berhasil digunakan dalam mengimplementasikan server jaringan dan server web. Mereka juga menyediakan fondasi yang sesuai untuk eksekusi paralel aplikasi pada multiprosesor memori bersama. Gambar berikut menunjukkan cara kerja proses single-threaded dan multithread.

Perbedaan antara Proses dan Thread

SN Proses Benang
1 Prosesnya berat atau intensif sumber daya. Benang itu ringan, mengambil sumber daya lebih sedikit daripada sebuah proses.
2 Proses switching membutuhkan interaksi dengan sistem operasi. Peralihan benang tidak perlu berinteraksi dengan sistem operasi.
3 Dalam beberapa lingkungan pemrosesan, setiap proses menjalankan kode yang sama tetapi memiliki memori dan sumber daya file sendiri. Semua utas dapat berbagi kumpulan file terbuka yang sama, proses anak.
4 Jika satu proses diblokir, maka tidak ada proses lain yang dapat dijalankan hingga proses pertama tidak diblokir. Saat satu utas diblokir dan menunggu, utas kedua dalam tugas yang sama dapat berjalan.
5 Beberapa proses tanpa menggunakan utas menggunakan lebih banyak sumber daya. Beberapa proses berulir menggunakan lebih sedikit sumber daya.
6 Dalam banyak proses, setiap proses beroperasi secara independen dari yang lain. Satu utas dapat membaca, menulis, atau mengubah data utas lainnya.

Keuntungan dari Thread

  • Utas meminimalkan waktu peralihan konteks.
  • Penggunaan utas menyediakan konkurensi dalam suatu proses.
  • Komunikasi yang efisien.
  • Lebih ekonomis untuk membuat dan mengubah konteks utas sakelar.
  • Benang memungkinkan pemanfaatan arsitektur multiprosesor ke skala dan efisiensi yang lebih besar.

Jenis Benang

Utas diimplementasikan dengan dua cara berikut -

  • User Level Threads - Utas yang dikelola pengguna.

  • Kernel Level Threads - Thread yang dikelola Sistem Operasi yang bekerja pada kernel, inti sistem operasi.

Utas Tingkat Pengguna

Dalam hal ini, kernel manajemen utas tidak mengetahui keberadaan utas. Pustaka utas berisi kode untuk membuat dan menghancurkan utas, untuk meneruskan pesan dan data antar utas, untuk menjadwalkan eksekusi utas dan untuk menyimpan dan memulihkan konteks utas. Aplikasi dimulai dengan satu utas.

Keuntungan

  • Peralihan utas tidak memerlukan hak mode Kernel.
  • Utas tingkat pengguna dapat berjalan di sistem operasi apa pun.
  • Penjadwalan dapat menjadi aplikasi khusus di utas tingkat pengguna.
  • Utas tingkat pengguna cepat dibuat dan dikelola.

Kekurangan

  • Dalam sistem operasi tipikal, sebagian besar panggilan sistem diblokir.
  • Aplikasi multithread tidak dapat memanfaatkan multiprosesing.

Utas Tingkat Kernel

Dalam hal ini, manajemen thread dilakukan oleh Kernel. Tidak ada kode manajemen utas di area aplikasi. Utas kernel didukung langsung oleh sistem operasi. Aplikasi apa pun dapat diprogram untuk menjadi multithread. Semua utas dalam aplikasi didukung dalam satu proses.

Kernel memelihara informasi konteks untuk proses secara keseluruhan dan untuk utas individu dalam proses. Penjadwalan oleh Kernel dilakukan pada basis utas. Kernel melakukan pembuatan, penjadwalan, dan manajemen utas di ruang Kernel. Utas kernel umumnya lebih lambat untuk dibuat dan dikelola daripada utas pengguna.

Keuntungan

  • Kernel dapat secara bersamaan menjadwalkan beberapa utas dari proses yang sama pada beberapa proses.
  • Jika satu utas dalam suatu proses diblokir, Kernel dapat menjadwalkan utas lain dari proses yang sama.
  • Rutinitas kernel itu sendiri bisa multithread.

Kekurangan

  • Utas kernel umumnya lebih lambat untuk dibuat dan dikelola daripada utas pengguna.
  • Transfer kendali dari satu utas ke utas lainnya dalam proses yang sama membutuhkan peralihan mode ke Kernel.

Model Multithreading

Beberapa sistem operasi menyediakan gabungan utas tingkat pengguna dan fasilitas utas tingkat kernel. Solaris adalah contoh bagus dari pendekatan gabungan ini. Dalam sistem gabungan, beberapa utas dalam aplikasi yang sama dapat berjalan secara paralel pada banyak prosesor dan panggilan sistem pemblokiran tidak perlu memblokir seluruh proses. Model multithreading ada tiga jenis

  • Banyak ke banyak hubungan.
  • Banyak ke satu hubungan.
  • Hubungan satu lawan satu.

Model Banyak ke Banyak

Model banyak-ke-banyak menggandakan sejumlah utas pengguna ke sejumlah utas kernel yang sama atau lebih kecil.

Diagram berikut menunjukkan model threading banyak ke banyak di mana 6 utas tingkat pengguna melakukan multipleks dengan 6 utas tingkat kernel. Dalam model ini, pengembang dapat membuat utas pengguna sebanyak yang diperlukan dan utas Kernel yang sesuai dapat berjalan secara paralel di mesin multiprosesor. Model ini memberikan akurasi terbaik pada konkurensi dan ketika sebuah thread melakukan panggilan sistem pemblokiran, kernel dapat menjadwalkan thread lain untuk dieksekusi.

Banyak untuk Satu Model

Model banyak-ke-satu memetakan banyak utas tingkat pengguna ke satu utas tingkat kernel. Manajemen utas dilakukan di ruang pengguna oleh perpustakaan utas. Saat utas membuat panggilan sistem pemblokiran, seluruh proses akan diblokir. Hanya satu utas yang dapat mengakses Kernel pada satu waktu, sehingga banyak utas tidak dapat berjalan secara paralel di multiprosesor.

Jika pustaka utas tingkat pengguna diimplementasikan dalam sistem operasi sedemikian rupa sehingga sistem tidak mendukungnya, maka utas kernel menggunakan mode hubungan banyak-ke-satu.

Model Satu ke Satu

Ada hubungan satu-ke-satu dari utas tingkat pengguna dengan utas tingkat kernel. Model ini memberikan lebih banyak konkurensi daripada model banyak-ke-satu. Ini juga memungkinkan utas lain berjalan saat utas membuat panggilan sistem pemblokiran. Ini mendukung banyak utas untuk dieksekusi secara paralel pada mikroprosesor.

Kerugian dari model ini adalah bahwa membuat utas pengguna membutuhkan utas Kernel yang sesuai. OS / 2, windows NT dan windows 2000 menggunakan model hubungan satu ke satu.

Perbedaan antara User-Level & Kernel-Level Thread

SN Untaian Tingkat Pengguna Utas Tingkat Kernel
1 Untaian tingkat pengguna lebih cepat dibuat dan dikelola. Utas tingkat kernel lebih lambat untuk dibuat dan dikelola.
2 Implementasinya dilakukan dengan pustaka utas di tingkat pengguna. Sistem operasi mendukung pembuatan utas Kernel.
3 Utas tingkat pengguna bersifat umum dan dapat berjalan di sistem operasi apa pun. Utas tingkat kernel dikhususkan untuk sistem operasi.
4 Aplikasi multi-thread tidak dapat memanfaatkan multiprocessing. Rutinitas kernel itu sendiri bisa multithread.