Concurrency dalam Python - Pendahuluan
Dalam bab ini, kita akan memahami konsep konkurensi dengan Python dan mempelajari tentang berbagai utas dan proses.
Apa itu Concurrency?
Dengan kata sederhana, konkurensi adalah terjadinya dua atau lebih peristiwa pada saat yang bersamaan. Konkurensi adalah fenomena alam karena banyak peristiwa terjadi secara bersamaan pada waktu tertentu.
Dalam hal pemrograman, konkurensi adalah ketika dua tugas tumpang tindih dalam eksekusi. Dengan pemrograman bersamaan, kinerja aplikasi dan sistem perangkat lunak kami dapat ditingkatkan karena kami dapat menangani permintaan secara bersamaan daripada menunggu yang sebelumnya diselesaikan.
Review Historis Concurrency
Poin-poin berikut akan memberi kita tinjauan sejarah singkat tentang konkurensi -
Dari konsep rel kereta api
Concurrency erat kaitannya dengan konsep rel kereta api. Dengan rel kereta api, ada kebutuhan untuk menangani banyak kereta di sistem rel yang sama sedemikian rupa sehingga setiap kereta dapat mencapai tujuannya dengan selamat.
Komputasi serentak di dunia akademis
Ketertarikan pada ilmu komputer konkurensi dimulai dengan makalah penelitian yang diterbitkan oleh Edsger W. Dijkstra pada tahun 1965. Dalam makalah ini, ia mengidentifikasi dan memecahkan masalah pengecualian bersama, properti dari kontrol konkurensi.
Primitif konkurensi tingkat tinggi
Belakangan ini, programmer mendapatkan solusi konkuren yang lebih baik karena pengenalan primitif konkurensi tingkat tinggi.
Peningkatan konkurensi dengan bahasa pemrograman
Bahasa pemrograman seperti Google Golang, Rust dan Python telah membuat perkembangan luar biasa di area yang membantu kami mendapatkan solusi bersamaan yang lebih baik.
Apa itu Thread & Multithreading?
Threadadalah unit eksekusi terkecil yang dapat dilakukan di sistem operasi. Itu sendiri bukanlah sebuah program tetapi berjalan di dalam sebuah program. Dengan kata lain, utas tidak independen satu sama lain. Setiap utas berbagi bagian kode, bagian data, dll. Dengan utas lainnya. Mereka juga dikenal sebagai proses ringan.
Utas terdiri dari komponen berikut -
Penghitung program yang terdiri dari alamat instruksi yang dapat dieksekusi berikutnya
Stack
Set register
ID unik
Multithreading, di sisi lain, adalah kemampuan CPU untuk mengelola penggunaan sistem operasi dengan mengeksekusi beberapa thread secara bersamaan. Ide utama multithreading adalah mencapai paralelisme dengan membagi proses menjadi beberapa utas. Konsep multithreading dapat dipahami dengan bantuan contoh berikut.
Contoh
Misalkan kita menjalankan proses tertentu dimana kita membuka MS Word untuk mengetikkan konten ke dalamnya. Satu utas akan ditugaskan untuk membuka MS Word dan utas lain akan diminta untuk mengetik konten di dalamnya. Dan sekarang, jika kita ingin mengedit yang sudah ada maka diperlukan utas lain untuk melakukan tugas pengeditan dan seterusnya.
Apa itu Proses & Multiprosesing?
SEBUAHprocessDidefinisikan sebagai entitas, yang merepresentasikan unit kerja dasar yang akan dilaksanakan dalam sistem. Sederhananya, kami menulis program komputer kami dalam file teks dan ketika kami menjalankan program ini, itu menjadi proses yang melakukan semua tugas yang disebutkan dalam program. Selama siklus hidup proses, ini melewati tahapan yang berbeda - Mulai, Siap, Berjalan, Menunggu dan Mengakhiri.
Diagram berikut menunjukkan berbagai tahapan proses -
Suatu proses hanya dapat memiliki satu utas, yang disebut utas utama, atau beberapa utas yang memiliki set register, penghitung program, dan tumpukannya sendiri. Diagram berikut akan menunjukkan perbedaannya -
Multiprocessing,di sisi lain, adalah penggunaan dua atau lebih unit CPU dalam satu sistem komputer. Tujuan utama kami adalah mendapatkan potensi penuh dari perangkat keras kami. Untuk mencapai ini, kita perlu memanfaatkan seluruh core CPU yang tersedia di sistem komputer kita. Multiprocessing adalah pendekatan terbaik untuk melakukannya.
Python adalah salah satu bahasa pemrograman paling populer. Berikut adalah beberapa alasan yang membuatnya cocok untuk aplikasi bersamaan -
Gula sintaksis
Gula sintaksis adalah sintaks dalam bahasa pemrograman yang dirancang untuk membuat sesuatu lebih mudah dibaca atau diungkapkan. Itu membuat bahasa menjadi "lebih manis" untuk digunakan manusia: hal-hal dapat diungkapkan dengan lebih jelas, lebih ringkas, atau dalam gaya alternatif berdasarkan preferensi. Python hadir dengan metode Magic, yang dapat didefinisikan untuk bekerja pada objek. Metode Ajaib ini digunakan sebagai gula sintaksis dan terikat pada kata kunci yang lebih mudah dipahami.
Komunitas Besar
Bahasa Python telah menyaksikan tingkat adopsi besar-besaran di antara ilmuwan data dan ahli matematika, bekerja di bidang AI, pembelajaran mesin, pembelajaran mendalam, dan analisis kuantitatif.
API yang berguna untuk pemrograman bersamaan
Python 2 dan 3 memiliki sejumlah besar API yang didedikasikan untuk pemrograman paralel / bersamaan. Yang paling populer adalahthreading, concurrent.features, multiprocessing, asyncio, gevent and greenlets, dll.
Batasan Python dalam mengimplementasikan aplikasi bersamaan
Python hadir dengan batasan untuk aplikasi bersamaan. Batasan ini disebutGIL (Global Interpreter Lock)hadir dalam Python. GIL tidak pernah mengizinkan kita untuk menggunakan banyak inti CPU dan karenanya kita dapat mengatakan bahwa tidak ada utas yang sebenarnya dalam Python. Kita dapat memahami konsep GIL sebagai berikut -
GIL (Kunci Interpreter Global)
Ini adalah salah satu topik paling kontroversial di dunia Python. Di CPython, GIL adalah mutex - kunci pengecualian bersama, yang membuat utas semuanya aman. Dengan kata lain, kita dapat mengatakan bahwa GIL mencegah banyak utas mengeksekusi kode Python secara paralel. Kunci dapat dipegang hanya oleh satu utas pada satu waktu dan jika kita ingin mengeksekusi utas maka harus mendapatkan kunci terlebih dahulu. Diagram yang ditunjukkan di bawah ini akan membantu Anda memahami cara kerja GIL.
Namun, ada beberapa pustaka dan implementasi dengan Python seperti Numpy, Jpython dan IronPytbhon. Pustaka ini bekerja tanpa interaksi apa pun dengan GIL.