Proses ialah konsep sistem pengendalian Setiap kali kita melaksanakan program, proses dicipta untuk sistem pengendalian Dalam proses ini, sumber diperuntukkan dan dikeluarkan. Sesuatu proses boleh dianggap sebagai pelaksanaan program.
Ruang pengguna proses adalah bebas antara satu sama lain dan secara amnya tidak boleh mengakses satu sama lain. Tetapi dalam banyak kes, proses perlu berkomunikasi antara satu sama lain untuk melengkapkan fungsi tertentu sistem. Proses menyelaraskan tingkah laku mereka dengan berkomunikasi dengan kernel dan proses lain.
Pemindahan data: Satu proses perlu menghantar datanya ke proses lain dan jumlah data yang dihantar berjulat dari satu bait hingga beberapa megabait.
Data kongsi: Pelbagai proses mahu mengendalikan data kongsi Jika satu proses mengubah suai data kongsi, proses lain akan melihatnya dengan segera.
Peristiwa pemberitahuan: Proses perlu menghantar mesej kepada proses lain atau sekumpulan proses untuk memberitahunya (mereka) bahawa peristiwa tertentu telah berlaku (seperti memberitahu proses induk apabila proses ditamatkan).
Perkongsian sumber: berkongsi sumber yang sama antara pelbagai proses. Untuk melakukan ini, kernel perlu menyediakan mekanisme penguncian dan penyegerakan.
Kawalan proses: Sesetengah proses ingin mengawal sepenuhnya pelaksanaan proses lain (seperti proses Nyahpepijat Pada masa ini, proses kawalan berharap dapat memintas semua perangkap dan pengecualian proses lain dan dapat mengetahui statusnya). perubahan masa.
Paip dibahagikan kepada paip bernama dan paip tidak bernama
Paip yang tidak dinamakan ialah kaedah komunikasi separuh dupleks Data hanya boleh mengalir dalam satu arah dan hanya boleh digunakan antara proses yang mempunyai pertalian. Paip kejahilan biasanya digunakan untuk komunikasi antara dua proses yang berbeza. Apabila proses mencipta paip dan memanggil fork untuk mencipta proses anak sendiri, proses induk menutup hujung paip baca dan proses anak menutup hujung paip tulis Ini menyediakan cara untuk data mengalir antara kedua-dua proses.
Paip yang terkenal juga merupakan kaedah komunikasi separuh dupleks, tetapi ia membolehkan komunikasi antara proses yang tidak berkaitan.
Semaphore ialah pembilang yang boleh digunakan untuk mengawal akses berbilang utas kepada sumber yang dikongsi Ia tidak digunakan untuk menukar sejumlah besar data, tetapi digunakan untuk penyegerakan antara berbilang utas Ia sering digunakan sebagai mekanisme kunci untuk menghalang proses daripada Apabila mengakses sumber, proses lain turut mengakses sumber Oleh itu, ia digunakan terutamanya sebagai cara penyegerakan antara proses dan antara utas yang berbeza dalam proses yang sama.
Linux menyediakan satu set antara muka semaphore yang direka dengan baik untuk mengendalikan isyarat Ia bukan sahaja untuk semaphore binari, tetapi sila ambil perhatian bahawa fungsi ini digunakan untuk mengendalikan kumpulan isyarat. Mereka diisytiharkan dalam fail pengepala sys/sem.h.
fungsi semget
Fungsinya adalah untuk mencipta semafor baru atau mendapatkan semafor sedia ada
fungsi semop
Fungsinya adalah untuk menukar nilai semaphore
fungsi semctl
Fungsi ini digunakan untuk mengawal terus maklumat semaphore
Isyarat ialah kaedah komunikasi yang agak kompleks yang digunakan untuk memberitahu proses penerimaan bahawa sesuatu peristiwa telah berlaku
Baris gilir mesej ialah senarai mesej yang dipautkan, yang disimpan dalam kernel dan dikenal pasti oleh pengecam baris gilir mesej Barisan gilir mesej mengatasi ciri-ciri maklumat penghantaran isyarat yang kurang, saluran paip hanya boleh membawa aliran bait yang tidak diformat dan penimbal terhad. saiz. Baris gilir mesej adalah Mekanisme untuk berkongsi sumber antara proses yang berbeza di bawah UNIX membenarkan proses yang berbeza untuk menghantar aliran data yang diformatkan ke mana-mana proses dalam bentuk baris gilir mesej dengan kebenaran operasi pada baris gilir mesej barisan mesej Kawalan operasi Dengan menggunakan jenis mesej, proses boleh membaca maklumat dalam sebarang susunan, atau mengutamakan mesej
Memori dikongsi adalah untuk memetakan bahagian memori yang boleh diakses oleh proses lain Memori dikongsi ini dicipta oleh satu proses, tetapi boleh diakses oleh pelbagai proses adalah kaedah IPC (komunikasi antara proses), yang disasarkan pada proses lain. Komunikasi antara proses direka khas untuk kecekapan operasi yang rendah Ia sering digunakan bersama dengan mekanisme komunikasi lain, seperti semafor, untuk mencapai penyegerakan dan komunikasi antara proses.
Ciri soket ditentukan oleh 3 atribut: domain, jenis dan protokol.
Boleh digunakan untuk komunikasi antara berbeza dan antara proses
Atas ialah kandungan terperinci 6 cara untuk berkomunikasi antara proses Linux. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!